mirror of
https://github.com/uparrows/LANraragi_cn.git
synced 2025-01-08 12:07:29 +08:00
test build
This commit is contained in:
parent
1b863b8c62
commit
c7b50444d9
72
Dockerfile
72
Dockerfile
@ -1,8 +1,7 @@
|
||||
# DOCKER-VERSION 0.3.4
|
||||
FROM alpine:3.12
|
||||
LABEL git="https://github.com/uparrows/LANraragi_cn"
|
||||
FROM alpine:3.16
|
||||
LABEL git="https://github.com/Difegue/LANraragi"
|
||||
|
||||
ENV S6_OVERLAY_RELEASE v2.0.0.1
|
||||
ENV S6_KEEP_ENV 1
|
||||
|
||||
# warn if we can't run stage2 (fix-attrs/cont-init)
|
||||
@ -10,9 +9,11 @@ ENV S6_BEHAVIOUR_IF_STAGE2_FAILS 1
|
||||
|
||||
# wait 10s before KILLing
|
||||
ENV S6_KILL_GRACETIME 10000
|
||||
ENV S6_CMD_WAIT_FOR_SERVICES_MAXTIME 0
|
||||
|
||||
# s6
|
||||
ENTRYPOINT ["/init"]
|
||||
# s6: The init is provided by alpine's s6-overlay package, hence the double slash.
|
||||
# See https://pkgs.alpinelinux.org/contents?branch=v3.14&name=s6-overlay&arch=x86&repo=community
|
||||
ENTRYPOINT ["//init"]
|
||||
|
||||
# Check application health
|
||||
HEALTHCHECK --interval=1m --timeout=10s --retries=3 \
|
||||
@ -22,49 +23,54 @@ HEALTHCHECK --interval=1m --timeout=10s --retries=3 \
|
||||
#Default mojo server port
|
||||
EXPOSE 3000
|
||||
|
||||
#Enable UTF-8 (might not do anything extra on alpine tho)
|
||||
# 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=0 LRR_GID=0 \
|
||||
#Environment variables overridable by the user on container deployment
|
||||
# rootless user id
|
||||
LRR_UID=9001 LRR_GID=9001 \
|
||||
# Environment variables overridable by the user on container deployment
|
||||
LRR_NETWORK=http://*:3000 \
|
||||
# extra variables
|
||||
EV_EXTRA_DEFS=-DEV_NO_ATFORK
|
||||
EV_EXTRA_DEFS=-DEV_NO_ATFORK \
|
||||
# Enable automatic http proxy detection for mojo
|
||||
MOJO_PROXY=1 \
|
||||
# Allow Mojo to automatically pick up the X-Forwarded-For and X-Forwarded-Proto headers
|
||||
MOJO_REVERSE_PROXY=1
|
||||
|
||||
RUN \
|
||||
if [ $(getent group ${LRR_GID}) ]; then \
|
||||
adduser -D -u ${LRR_UID} koyomi; \
|
||||
else \
|
||||
addgroup -g ${LRR_GID} koyomi && \
|
||||
adduser -D -u ${LRR_UID} -G koyomi koyomi; \
|
||||
fi
|
||||
|
||||
|
||||
# we use s6-overlay-nobin to just pull in the s6-overlay arch agnostic (shell)
|
||||
# components, since we apk install the binaries of s6 later which are arch specific
|
||||
# /!\ While the s6 version here is fixed by an envvar, the apk install is not pinned and takes whatever's in alpine:latest! This certainly needs a fix.
|
||||
ADD https://github.com/just-containers/s6-overlay/releases/download/${S6_OVERLAY_RELEASE}/s6-overlay-nobin.tar.gz /tmp/s6-overlay-nobin.tar.gz
|
||||
RUN tar -C / -xzf /tmp/s6-overlay-nobin.tar.gz && rm -f /tmp/s6-overlay-nobin.tar.gz
|
||||
|
||||
|
||||
WORKDIR /root/lanraragi
|
||||
WORKDIR /home/koyomi/lanraragi
|
||||
|
||||
#Copy cpanfile and install script before copying the entire context
|
||||
#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=koyomi:koyomi /tools/cpanfile /tools/install.pl /tools/build/docker/install-everything.sh tools/
|
||||
COPY --chown=koyomi:koyomi /package.json package.json
|
||||
|
||||
# Run the install script as root
|
||||
RUN sh ./tools/install-everything.sh
|
||||
RUN rm -f /root/lanraragi/public/js/vendor/jquery.dataTables.min.js
|
||||
#Copy remaining LRR files from context
|
||||
# consider chowning in s6 setup scripts instead
|
||||
COPY --chown=root:root /lib lib
|
||||
COPY --chown=root:root /public public
|
||||
COPY --chown=root:root /script script
|
||||
COPY --chown=root:root /templates templates
|
||||
COPY --chown=root:root /tests tests
|
||||
COPY --chown=root:root /lrr.conf lrr.conf
|
||||
COPY --chown=root:root /tools/build/docker/redis.conf tools/build/docker/
|
||||
COPY --chown=koyomi:koyomi /lib lib
|
||||
COPY --chown=koyomi:koyomi /public public
|
||||
COPY --chown=koyomi:koyomi /script script
|
||||
COPY --chown=koyomi:koyomi /templates templates
|
||||
COPY --chown=koyomi:koyomi /tests tests
|
||||
COPY --chown=koyomi:koyomi /lrr.conf lrr.conf
|
||||
COPY --chown=koyomi:koyomi /tools/build/docker/redis.conf tools/build/docker/
|
||||
COPY /tools/build/docker/wsl.conf /etc/wsl.conf
|
||||
COPY /tools/build/docker/s6/cont-init.d/ /etc/cont-init.d/
|
||||
COPY /tools/build/docker/s6/services.d/ /etc/services.d/
|
||||
#Copy s6-overlay 3.x services
|
||||
#Uses a system-d like definition that can't be use in 2.x
|
||||
COPY /tools/build/docker/s6/s6-rc.d/ /etc/s6-overlay/s6-rc.d/
|
||||
#Copy setup script as-is since no changes are needed between 2.x and 3.x
|
||||
COPY /tools/build/docker/s6/cont-init.d/01-lrr-setup /etc/s6-overlay/s6-rc.d/init/
|
||||
COPY --chown=root:root /jquery.dataTables.min.js /root/lanraragi/public/js/vendor/jquery.dataTables.min.js
|
||||
#COPY /tools/build/docker/s6/fix-attrs.d/ /etc/fix-attrs.d/
|
||||
|
||||
# Persistent volumes
|
||||
VOLUME [ "/root/lanraragi/content" ]
|
||||
VOLUME [ "/root/lanraragi/database"]
|
||||
VOLUME [ "/home/koyomi/lanraragi/content" ]
|
||||
VOLUME [ "/home/koyomi/lanraragi/database"]
|
||||
|
@ -1 +0,0 @@
|
||||
*log*
|
@ -11,7 +11,6 @@
|
||||
* [🛠 Source Code (Linux/macOS)](installing-lanraragi/source.md)
|
||||
* [🐧 Community (Linux)](installing-lanraragi/community.md)
|
||||
* [👿 Jail (FreeBSD)](installing-lanraragi/jail.md)
|
||||
* [🕸 Vagrant (Deprecated)](installing-lanraragi/vagrant.md)
|
||||
|
||||
## Basic Operations
|
||||
|
||||
@ -30,6 +29,7 @@
|
||||
* [💾 Backup and Restore](advanced-usage/backup-and-restore.md)
|
||||
* [📱 Using External Readers](advanced-usage/external-readers.md)
|
||||
* [🌐 Network Interface Setup](advanced-usage/network-interfaces.md)
|
||||
* [🕵️ Proxy Setup](advanced-usage/proxy-setup.md)
|
||||
* [📏 Tag Rules](advanced-usage/tag-rules.md)
|
||||
|
||||
## Developer Guide <a href="extending-lanraragi" id="extending-lanraragi"></a>
|
||||
@ -45,6 +45,7 @@
|
||||
* [Database API](api-documentation/database-api.md)
|
||||
* [Category API](api-documentation/category-api.md)
|
||||
* [Shinobu API](api-documentation/shinobu-api.md)
|
||||
* [Minion API](api-documentation/minion-api.md)
|
||||
* [Miscellaneous other API](api-documentation/miscellaneous-other-api.md)
|
||||
|
||||
## Writing Plugins <a href="plugin-docs" id="plugin-docs"></a>
|
||||
|
@ -12,6 +12,11 @@ This allows you to seamlessly add archives from the Internet to your LRR instanc
|
||||
By default, we will try to download any URL you chuck at us! This will mostly work for simple URLs that point directly to a file we support.
|
||||
(For example, something like this very nice Quake booklet: `https://archive.org/download/quake-essays-sep-15-fin-4-graco-l-cl/QUAKE_essays_SEP15_FIN4_GRACoL_CL.pdf` will download without a fuss.)
|
||||
|
||||
{% hint style="info" %}
|
||||
Downloaded archives will automatically get a `source:` tag with the URL they were downloaded from.
|
||||
Said source tags can often be used with compatible Metadata plugins to fetch metadata precisely. (Supported by E-H and nH)
|
||||
{% endhint %}
|
||||
|
||||
For non-direct links, you will need to have a matching **Downloader Plugin** configured.
|
||||
LANraragi currently ships with Downloaders handling E-H and Chaika links.
|
||||
|
||||
|
67
tools/Documentation/advanced-usage/proxy-setup.md
Normal file
67
tools/Documentation/advanced-usage/proxy-setup.md
Normal file
@ -0,0 +1,67 @@
|
||||
# 🕵️ Proxy Setup
|
||||
|
||||
## Setting up LANraragi behind a proxy (reverse proxy setup)
|
||||
|
||||
A common post-install setup is to make requests to the app transit through a gateway server such as Apache or nginx.
|
||||
If you do so, please note that archive uploads through LRR will likely **not work out of the box** due to maximum sizes on uploads those servers can enforce. The example below is for nginx:
|
||||
|
||||
```
|
||||
http {
|
||||
client_max_body_size 0; <----------------------- This line here
|
||||
}
|
||||
|
||||
server {
|
||||
listen 80;
|
||||
|
||||
server_name lanraragi.[REDACTED].net;
|
||||
|
||||
return 301 https://$host$request_uri;
|
||||
}
|
||||
|
||||
server {
|
||||
listen 443 ssl;
|
||||
index index.php index.html index.htm;
|
||||
server_name lanraragi.[REDACTED].net;
|
||||
|
||||
client_max_body_size 0; <----------------------- And this line here
|
||||
|
||||
# Cert Stuff Omitted
|
||||
|
||||
location / {
|
||||
proxy_pass http://0.0.0.0:3000;
|
||||
proxy_http_version 1.1;
|
||||
<----- The two following lines are needed for batch tagger support with SSL ----->
|
||||
proxy_set_header Upgrade $http_upgrade;
|
||||
proxy_set_header Connection $connection_upgrade;
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
## Setting up LANraragi to use a proxy for outbound network requests
|
||||
|
||||
This is a less common scenario, but you might want to have downloads or metadata requests to external services go through a proxy, in case said external services are blocked by your friendly local totalitarian regime.
|
||||
|
||||
LANraragi runs on top of the Mojolicious web server, which has [built-in](https://docs.mojolicious.org/Mojo/UserAgent/Proxy#detect) support for proxifying external requests.
|
||||
|
||||
To enable automatic proxy detection, the `MOJO_PROXY` environment variable must be set to 1 on your machine: This is enabled by default on Docker builds.
|
||||
Once said detection enabled, environment variables `HTTP_PROXY, http_proxy, HTTPS_PROXY, https_proxy, NO_PROXY` and `no_proxy` will be checked for proxy information.
|
||||
|
||||
Here's an example for a Docker-compose setup:
|
||||
|
||||
```
|
||||
---
|
||||
version: "2.1"
|
||||
services:
|
||||
lanraragi:
|
||||
image: difegue/lanraragi:latest
|
||||
container_name: lanraragi
|
||||
environment:
|
||||
- http_proxy=http://192.168.10.186:1082
|
||||
- https_proxy=http://192.168.10.186:1082
|
||||
volumes:
|
||||
- [database]:/home/koyomi/lanraragi/database
|
||||
- [content]:/home/koyomi/lanraragi/content
|
||||
ports:
|
||||
- 7070:3000
|
||||
restart: unless-stopped
|
||||
```
|
@ -10,11 +10,7 @@ Get tags from the database, with a value symbolizing their prevalence.
|
||||
{% endswagger-description %}
|
||||
|
||||
{% swagger-parameter name="minweight" type="int" required="false" in="query" %}
|
||||
Add this parameter if you want to only get tags whose weight is at least the given minimum.
|
||||
|
||||
\
|
||||
|
||||
|
||||
Add this parameter if you want to only get tags whose weight is at least the given minimum.
|
||||
Default is 1 if not specified, to get all tags.
|
||||
{% endswagger-parameter %}
|
||||
|
||||
@ -51,11 +47,7 @@ Cleans the Database, removing entries for files that are no longer on the filesy
|
||||
|
||||
{% swagger baseUrl="http://lrr.tvc-16.science" path="/api/database/drop" method="post" summary="🔑Drop the Database" %}
|
||||
{% swagger-description %}
|
||||
Delete the entire database, including user preferences.
|
||||
|
||||
\
|
||||
|
||||
|
||||
Delete the entire database, including user preferences.
|
||||
This is a rather dangerous endpoint, invoking it might lock you out of the server as a client!
|
||||
{% endswagger-description %}
|
||||
|
||||
@ -71,11 +63,7 @@ This is a rather dangerous endpoint, invoking it might lock you out of the serve
|
||||
|
||||
{% swagger baseUrl="http://lrr.tvc-16.science" path="/api/database/backup" method="get" summary="🔑Get a backup JSON" %}
|
||||
{% swagger-description %}
|
||||
Scans the entire database and returns a backup in JSON form.
|
||||
|
||||
\
|
||||
|
||||
|
||||
Scans the entire database and returns a backup in JSON form.
|
||||
This backup can be reimported manually through the Backup and Restore feature.
|
||||
{% endswagger-description %}
|
||||
|
||||
|
77
tools/Documentation/api-documentation/minion-api.md
Normal file
77
tools/Documentation/api-documentation/minion-api.md
Normal file
@ -0,0 +1,77 @@
|
||||
---
|
||||
description: Control the built-in Minion Job Queue.
|
||||
---
|
||||
|
||||
# Minion API
|
||||
|
||||
{% swagger baseUrl="http://lrr.tvc-16.science" path="/api/minion/:jobid" method="get" summary="Get the basic status of a Minion Job" %}
|
||||
{% swagger-description %}
|
||||
For a given Minion job ID, check whether it succeeded or failed.
|
||||
Minion jobs are ran for various occasions like thumbnails, cache warmup and handling incoming files.
|
||||
{% endswagger-description %}
|
||||
|
||||
{% swagger-parameter name="id" type="string" required="true" in="path" %}
|
||||
ID of the Job.
|
||||
{% endswagger-parameter %}
|
||||
|
||||
{% swagger-response status="200" description="You get job data." %}
|
||||
```javascript
|
||||
{
|
||||
"state": "finished",
|
||||
"task": "handle_upload",
|
||||
"error": null
|
||||
}
|
||||
|
||||
{
|
||||
"state": "failed",
|
||||
"task": "thumbnail_task",
|
||||
"error": "oh no"
|
||||
}
|
||||
```
|
||||
{% endswagger-response %}
|
||||
{% endswagger %}
|
||||
|
||||
{% swagger baseUrl="http://lrr.tvc-16.science" path="/api/minion/:jobid/detail" method="get" summary="🔑Get the full status of a Minion Job" %}
|
||||
{% swagger-description %}
|
||||
Get the status of a Minion Job.
|
||||
This API is there for internal usage mostly, but you can use it to get detailed status for jobs like plugin runs or URL downloads.
|
||||
{% endswagger-description %}
|
||||
|
||||
{% swagger-parameter name="id" type="string" required="true" in="path" %}
|
||||
ID of the Job.
|
||||
{% endswagger-parameter %}
|
||||
|
||||
{% swagger-response status="200" description="You get detailed job data." %}
|
||||
```javascript
|
||||
{
|
||||
"args": ["\/tmp\/QF3UCnKdMr\/myfile.zip"],
|
||||
"attempts": 1,
|
||||
"children": [],
|
||||
"created": "1601145004",
|
||||
"delayed": "1601145004",
|
||||
"expires": null,
|
||||
"finished": "1601145004",
|
||||
"id": 7,
|
||||
"lax": 0,
|
||||
"notes": {},
|
||||
"parents": [],
|
||||
"priority": 0,
|
||||
"queue": "default",
|
||||
"result": {
|
||||
"id": "75d18ce470dc99f83dc355bdad66319d1f33c82b",
|
||||
"message": "This file already exists in the Library.",
|
||||
"success": 0
|
||||
},
|
||||
"retried": null,
|
||||
"retries": 0,
|
||||
"started": "1601145004",
|
||||
"state": "finished",
|
||||
"task": "handle_upload",
|
||||
"time": "1601145005",
|
||||
"worker": 1
|
||||
}
|
||||
```
|
||||
{% endswagger-response %}
|
||||
{% endswagger %}
|
||||
|
||||
|
@ -283,10 +283,18 @@ You can either use `login`, `metadata`, `script`, or `all` to get all previous t
|
||||
{
|
||||
"desc": "Save archive title",
|
||||
"type": "bool"
|
||||
},
|
||||
{
|
||||
"desc": "Save the original title when available instead of the English or romanised title",
|
||||
"type": "bool"
|
||||
},
|
||||
{
|
||||
"desc": "Fetch additional timestamp (time posted) and uploader metadata",
|
||||
"type": "bool"
|
||||
}
|
||||
],
|
||||
"type": "metadata",
|
||||
"version": "2.2"
|
||||
"version": "2.3"
|
||||
},
|
||||
{
|
||||
"author": "Pao",
|
||||
@ -457,46 +465,3 @@ Whether to generate all thumbnails, or only the missing ones.
|
||||
```
|
||||
{% endswagger-response %}
|
||||
{% endswagger %}
|
||||
|
||||
{% swagger baseUrl="http://lrr.tvc-16.science" path="/api/minion/:jobid" method="get" summary="🔑Get the status of a Minion Job" %}
|
||||
{% swagger-description %}
|
||||
Get the status of a Minion Job. Minions jobs are ran for various occasions like thumbnails, cache warmup and handling incoming files.
|
||||
Usually stuff you don't need to care about as a client, but the API is there for internal usage mostly.
|
||||
{% endswagger-description %}
|
||||
|
||||
{% swagger-parameter name="id" type="string" required="true" in="path" %}
|
||||
ID of the Job.
|
||||
{% endswagger-parameter %}
|
||||
|
||||
{% swagger-response status="200" description="" %}
|
||||
```javascript
|
||||
{
|
||||
"args": ["\/tmp\/QF3UCnKdMr\/myfile.zip"],
|
||||
"attempts": 1,
|
||||
"children": [],
|
||||
"created": "1601145004",
|
||||
"delayed": "1601145004",
|
||||
"expires": null,
|
||||
"finished": "1601145004",
|
||||
"id": 7,
|
||||
"lax": 0,
|
||||
"notes": {},
|
||||
"parents": [],
|
||||
"priority": 0,
|
||||
"queue": "default",
|
||||
"result": {
|
||||
"id": "75d18ce470dc99f83dc355bdad66319d1f33c82b",
|
||||
"message": "This file already exists in the Library.",
|
||||
"success": 0
|
||||
},
|
||||
"retried": null,
|
||||
"retries": 0,
|
||||
"started": "1601145004",
|
||||
"state": "finished",
|
||||
"task": "handle_upload",
|
||||
"time": "1601145005",
|
||||
"worker": 1
|
||||
}
|
||||
```
|
||||
{% endswagger-response %}
|
||||
{% endswagger %}
|
||||
|
@ -40,3 +40,9 @@ Plugins have as much control over your system as the main LANraragi application
|
||||
|
||||
When installing Plugins from unknown sources, do a little research first.
|
||||
{% endhint %}
|
||||
|
||||
## About source: tags
|
||||
|
||||
If your archive has a `source:` tag (likely from the use of the [built-in downloading feature](../advanced-usage/downloading.md)), many plugins will use said tag to directly fetch metadata from it without having to use heuristics of any kind to guess what your archive is.
|
||||
|
||||
If you have the URL on hand directly, you can either add it as a `source:` tag to your archive, or use it as a one-shot parameter on most downloader plugins.
|
@ -24,7 +24,7 @@ Those variables were introduced for the Homebrew package, but they can be declar
|
||||
While Perl's mantra is "There's more than one way to do it", I try to make LRR follow the PBP, aka Perl Best Practices.
|
||||
This is done by the use of the [Perl::Critic](https://metacpan.org/pod/Perl::Critic) module, which reports PBP violations.
|
||||
If installed, you can run the critic on the entire LRR source tree through the `npm run critic` shortcut command.
|
||||
Critic is automatically run on every commit made to LRR at the level 5 thanks to [Github Actions](../../../.github/main.workflow).
|
||||
Critic is automatically run on every commit made to LRR at the level 5 thanks to [GitHub Actions](../../../.github/main.workflow).
|
||||
|
||||
I also run [perltidy](https://en.wikipedia.org/wiki/PerlTidy) on the source tree every now and then for consistency.
|
||||
The rules used in perltidy passes are stored in the .perltidyrc file at the source root.
|
||||
@ -47,14 +47,14 @@ I recommend trying to only use exported functions in your code, and consider the
|
||||
```
|
||||
root/
|
||||
|- .devcontainer <- VSCode setup files for Codespaces
|
||||
|- .github <- Github-specific files
|
||||
|- .github <- GitHub-specific files
|
||||
| |- action-run-tests <- Run the LRR Test Suite
|
||||
| |- ISSUE_TEMPLATE <- Template for bug reports
|
||||
| |- workflows <- Github Actions workflows
|
||||
| |- workflows <- GitHub Actions workflows
|
||||
| |- CD <- Continuous Delivery, Nightly builds
|
||||
| |- CI <- Tests
|
||||
| +- Release <- Build latest and upload .zip to release post on GH
|
||||
| +- FUNDING.yml <- Github Sponsors file
|
||||
| +- FUNDING.yml <- GitHub Sponsors file
|
||||
|
|
||||
|- content <- Default content folder
|
||||
|
|
||||
@ -117,7 +117,6 @@ root/
|
||||
| |- windows <- Windows build script and submodule link to the Karen WPF Bootstrapper
|
||||
| |- docker <- Dockerfile and configuration files for LRR Docker Container
|
||||
| |- homebrew <- Script and configuration files for the LRR Homebrew cask
|
||||
| |- vagrant <- Vagrantfile for LRR Vagrant Machine
|
||||
| |- cpanfile <- Perl dependencies description
|
||||
| |- install.pl <- LANraragi Installer
|
||||
| +- lanraragi-systemd.service <- Example SystemD service
|
||||
|
@ -12,43 +12,24 @@ Docker is the best way to install the software on remote servers. I don't recomm
|
||||
|
||||
## Cloning the base LRR image
|
||||
|
||||
Download [the Docker setup](https://www.docker.com/products/docker) and install it. Once you're done, execute:
|
||||
Download [the Docker setup](https://www.docker.com/products/docker) and install it.
|
||||
|
||||
{% hint style="warning" %}
|
||||
The LRR Docker container uses a fairly recent ([3.14](https://alpinelinux.org/posts/Alpine-3.14.0-released.html)) version of Alpine Linux as its base. I recommend you use at least Docker version **20.10.0** to avoid issues with the `faccessat2` syscall.
|
||||
You can check your Docker version by executing `docker version`.
|
||||
{% endhint %}
|
||||
|
||||
Once you're done, execute:
|
||||
```bash
|
||||
docker run --name=lanraragi -p 3000:3000 \
|
||||
--mount type=bind,source=[YOUR_CONTENT_DIRECTORY],target=/home/koyomi/lanraragi/content \
|
||||
--mount type=bind,source=[YOUR_DATABASE_DIRECTORY],target=/home/koyomi/lanraragi/database \
|
||||
difegue/lanraragi
|
||||
```
|
||||
|
||||
{% hint style="warning" %}
|
||||
If your Docker version is [_below 17.06_](https://docs.docker.com/storage/bind-mounts/) and you use the --mount option as listed above, you will get the following error:
|
||||
|
||||
```bash
|
||||
unknown flag: --mount
|
||||
See 'docker run --help'.
|
||||
```
|
||||
|
||||
You can bypass this issue by using the --volume option for bind-mounting like so:
|
||||
|
||||
```bash
|
||||
docker run --name=lanraragi -p 3000:3000 \
|
||||
--volume [YOUR_CONTENT_DIRECTORY]:/home/koyomi/lanraragi/content \
|
||||
--volume [YOUR_CONTENT_DIRECTORY]:/home/koyomi/lanraragi/database \
|
||||
difegue/lanraragi
|
||||
```
|
||||
{% endhint %}
|
||||
|
||||
{% hint style="info" %}
|
||||
You can tell Docker to auto-restart the LRR container on boot by adding the `--restart always` flag to this command.
|
||||
{% endhint %}
|
||||
|
||||
{% hint style="warning" %}
|
||||
If you're running on Windows, please check the syntax for mapping your content directory [here](https://docs.docker.com/docker-for-windows/#shared-drives).
|
||||
|
||||
Windows 7/8 users running the Legacy Docker toolbox will have to explicitly forward port 127.0.0.1:3000 from the host to the container in order to be able to access the app.
|
||||
{% endhint %}
|
||||
|
||||
The content directory you have to specify in the command above will contain archives you either upload through the software or directly drop in, alongside generated thumbnails.
|
||||
The database directory houses the LANraragi database(As database.rdb), allowing you to hotswap containers without losing any data.
|
||||
|
||||
@ -84,10 +65,28 @@ If you're feeling **extra dangerous**, you can run the last files directly from
|
||||
`docker run [zoinks] difegue/lanraragi:nightly`
|
||||
{% endhint %}
|
||||
|
||||
## Platform-specific caveats
|
||||
|
||||
### Windows
|
||||
If you're running on Windows, please check the syntax for mapping your content directory [here](https://docs.docker.com/docker-for-windows/#shared-drives).
|
||||
|
||||
Windows 7/8 users running the Legacy Docker toolbox will have to explicitly forward port 127.0.0.1:3000 from the host to the container in order to be able to access the app.
|
||||
### Raspbian
|
||||
|
||||
If you're using **Raspbian**, it's likely you'll encounter installation issues like `s6-svscan: warning: unable to iopause: Operation not permitted` due to their outdated version of `libseccomp`.
|
||||
You can fix this by either adding `--security-opt seccomp=unconfined` to your Docker arguments(discouraged, allows LRR wider access to underlying OS), or by installing an up-to-date version of `libseccomp`:
|
||||
|
||||
```bash
|
||||
wget http://ftp.debian.org/debian/pool/main/libs/libseccomp/libseccomp2_2.5.1-1~bpo10+1_armhf.deb
|
||||
sudo dpkg -i libseccomp2_2.5.1-1~bpo10+1_armhf.deb
|
||||
```
|
||||
|
||||
Regular versions of Debian shouldn't have this issue.
|
||||
|
||||
## Changing the port
|
||||
|
||||
Since Docker allows for port mapping, you can most of times map the default port of 3000 to another port on your host quickly.
|
||||
If you need something a bit more involved (like adding SSL), please check the Network Interfaces section for how to use thhe `LRR_NETWORK` environment variable.
|
||||
If you need something a bit more involved (like adding SSL), please check the Network Interfaces section for how to use the `LRR_NETWORK` environment variable.
|
||||
|
||||
{% content-ref url="../advanced-usage/network-interfaces.md" %}
|
||||
[network-interfaces.md](../advanced-usage/network-interfaces.md)
|
||||
@ -116,10 +115,13 @@ As Docker containers are immutable, you need to destroy your existing container
|
||||
docker pull difegue/lanraragi
|
||||
docker stop lanraragi
|
||||
docker rm lanraragi
|
||||
docker run --name=lanraragi -p 3000:3000 --mount type=bind,source=[YOUR_CONTENT_DIRECTORY],target=/home/koyomi/lanraragi/content difegue/lanraragi
|
||||
docker run --name=lanraragi -p 3000:3000 \
|
||||
--mount type=bind,source=[YOUR_CONTENT_DIRECTORY],target=/home/koyomi/lanraragi/content \
|
||||
--mount type=bind,source=[YOUR_DATABASE_DIRECTORY],target=/home/koyomi/lanraragi/database \
|
||||
difegue/lanraragi
|
||||
```
|
||||
|
||||
As long as you use the same content directory as the mount source, your data will still be there.
|
||||
As long as you use the same content/database directories as before, your data will still be there.
|
||||
|
||||
{% hint style="info" %}
|
||||
If you update often, you might want to consider using docker-compose or [Portainer](https://portainer.io) to redeploy containers without entering the entire configuration every time.
|
||||
|
@ -1,4 +1,4 @@
|
||||
# 🍎 Homebrew (macOS)
|
||||
# 🍎 Homebrew (macOS/Linux)
|
||||
|
||||
## Migration
|
||||
|
||||
@ -34,8 +34,9 @@ brew install lanraragi
|
||||
|
||||
## Configuration
|
||||
|
||||
Your content folder is stored by default in `${HOME}/Library/Application Support/LANraragi`.
|
||||
The Redis database is stored in `${HOME}/Library/Application Support/LANraragi/database`. The content folder can be moved to any folder you want through the in-app settings page.
|
||||
Your content folder is stored by default in `${HOME}/Library/Application Support/LANraragi`. (`${HOME}/LANraragi/content` on Linux.)
|
||||
The Redis database is stored in `${HOME}/Library/Application Support/LANraragi/database`. (`${HOME}/LANraragi/database` on Linux.)
|
||||
While the in-app settings page won't allow you to change the location of the content folder, you can do so by overriding the `LRR_DATA_DIRECTORY` environment variable before launching.
|
||||
|
||||
## Usage
|
||||
|
||||
@ -64,4 +65,4 @@ The same warning as in the Installation step applies.
|
||||
## Uninstallation
|
||||
|
||||
Run `brew remove lanraragi` to uninstall the app.
|
||||
Data in the `${HOME}/Library/Application Support/LANraragi` folder is not deleted.
|
||||
Data in the `${HOME}/Library/Application Support/LANraragi`/`${HOME}/LANraragi/` folder is not deleted.
|
||||
|
@ -9,9 +9,9 @@ However, a lot of work as been done behind the scenes to make it easy!
|
||||
|
||||
Look at the methods below for something that fits your OS and usage.
|
||||
|
||||
## macOS: _Homebrew_
|
||||
## Linux/macOS: _Homebrew_
|
||||
|
||||
[Homebrew](https://brew.sh) allows you to quickly setup LRR on macOS without relying on containers or modifying your preinstalled system libaries.
|
||||
[Homebrew](https://brew.sh) allows you to quickly setup LRR on macOS and Linux without relying on containers or modifying your preinstalled system libaries.
|
||||
|
||||
![brew](<../.screenshots/brew.jpg>)
|
||||
|
||||
@ -23,9 +23,6 @@ Look at the methods below for something that fits your OS and usage.
|
||||
|
||||
{% hint style="warning" %}
|
||||
This method works on **64-bit** editions of Windows 10 only.
|
||||
|
||||
Since LRR 0.8.0, you need Windows 10 version _1903_ at least. 0.7.9 will work with version _1809_ if you're on an LTSC channel.
|
||||
If you still want to use further server versions on 1809, a step-by-step workaround is available on the Windows documentation page below.
|
||||
{% endhint %}
|
||||
|
||||
![win10](../.screenshots/karen.jpg)
|
||||
@ -69,51 +66,8 @@ Similar to installing from source with an altered process for FreeBSD compatabil
|
||||
[jail.md](jail.md)
|
||||
{% endcontent-ref %}
|
||||
|
||||
## Older Windows: _Legacy Docker Toolbox or Vagrant_
|
||||
## Windows 7 or 8: don't
|
||||
|
||||
![I really hope you guys don't do this](../.screenshots/shiggy.png)
|
||||
|
||||
At this point the only solutions I have to give you are basically glorified VMs.
|
||||
|
||||
You can either download the [Legacy Docker Toolbox](https://docs.docker.com/toolbox/toolbox\_install\_windows/) and follow the Docker tutorial linked above, or try Vagrant. I provide **no support** for either of these methods.
|
||||
|
||||
{% content-ref url="vagrant.md" %}
|
||||
[vagrant.md](vagrant.md)
|
||||
{% endcontent-ref %}
|
||||
|
||||
## WARNING: Reverse Proxies
|
||||
|
||||
A common post-install setup is to make requests to the app transit through a gateway server such as Apache or nginx.
|
||||
If you do so, please note that archive uploads through LRR will likely **not work out of the box** due to maximum sizes on uploads those servers can enforce. The example below is for nginx:
|
||||
|
||||
```
|
||||
http {
|
||||
client_max_body_size 0; <----------------------- This line here
|
||||
}
|
||||
|
||||
server {
|
||||
listen 80;
|
||||
|
||||
server_name lanraragi.[REDACTED].net;
|
||||
|
||||
return 301 https://$host$request_uri;
|
||||
}
|
||||
|
||||
server {
|
||||
listen 443 ssl;
|
||||
index index.php index.html index.htm;
|
||||
server_name lanraragi.[REDACTED].net;
|
||||
|
||||
client_max_body_size 0; <----------------------- And this line here
|
||||
|
||||
# Cert Stuff Omitted
|
||||
|
||||
location / {
|
||||
proxy_pass http://0.0.0.0:3000;
|
||||
proxy_http_version 1.1;
|
||||
<----- The two following lines are needed for batch tagger support with SSL ----->
|
||||
proxy_set_header Upgrade $http_upgrade;
|
||||
proxy_set_header Connection $connection_upgrade;
|
||||
}
|
||||
}
|
||||
```
|
||||
Switch to 10 or Linux.
|
||||
|
@ -20,14 +20,14 @@ For information, my personal tests are done using Debian's vendor Perl.
|
||||
apt-get update
|
||||
apt-get upgrade -y
|
||||
apt-get install build-essential make gnupg pkg-config \
|
||||
cpanminus redis-server libarchive-dev imagemagick webp libssl-dev zlib1g-dev \
|
||||
cpanminus redis-server libarchive-dev imagemagick webp libssl-dev zlib1g-dev libjxl-dev \
|
||||
perlmagick ghostscript npm
|
||||
```
|
||||
|
||||
_Base software dependencies._
|
||||
|
||||
{% hint style="info" %}
|
||||
If your package manager requires you to specify which ImageMagick version to install you need to choose version 7.
|
||||
If your package manager requires you to specify which ImageMagick version to install, choose version 7.
|
||||
{% endhint %}
|
||||
|
||||
{% hint style="info" %}
|
||||
@ -44,7 +44,10 @@ git clone -b master http://github.com/Difegue/LANraragi /home/koyomi/lanraragi
|
||||
cd /home/koyomi/lanraragi && sudo npm run lanraragi-installer install-full
|
||||
```
|
||||
|
||||
Note: Do not use `sudo` in the above command if you are using `perlbrew`.
|
||||
{% hint style="info"}
|
||||
Do not use `sudo` in the above command if you are using `perlbrew`.
|
||||
Arch users might need to install `perl-config-autoconf` and use env variable `export PERL5LIB=~/perl5/lib/perl5` before running the installer.
|
||||
{% endhint %}
|
||||
|
||||
Once this is done, you can get started by running `npm start` and opening [http://localhost:3000](http://localhost:3000).
|
||||
|
||||
|
@ -1,52 +0,0 @@
|
||||
---
|
||||
description: >-
|
||||
For computers that are unable to easily use Docker or WSL(Basically just
|
||||
Windows 7 and 8), Vagrant allows you to quickly get started nonetheless.
|
||||
---
|
||||
|
||||
# 🕸 Vagrant (Deprecated)
|
||||
|
||||
{% hint style="danger" %}
|
||||
Vagrant installs are **deprecated** as of 0.6.0. They'll work, but come with enough potential issues and slowdowns that I don't recommend you use them at all!
|
||||
{% endhint %}
|
||||
|
||||
## Using the Vagrantfile
|
||||
|
||||
You can use the available Vagrantfile with [Vagrant](https://www.vagrantup.com/downloads.html) to deploy a virtual machine on your computer with LANraragi preinstalled.
|
||||
|
||||
{% hint style="info" %}
|
||||
This method requires [VirtualBox](https://www.virtualbox.org) to be installed on your machine!
|
||||
{% endhint %}
|
||||
|
||||
Download the [Vagrantfile](https://github.com/Difegue/LANraragi/tree/dev/tools/build/vagrant) that's relevant to the version of LANraragi that you want to install, then move it to your future LANraragi folder. If you downloaded the nightly Vagrantfile, be sure to remove `_nightly` from the end of the filename. Once you've done that, open a terminal in that folder and enter the following commands:
|
||||
|
||||
```
|
||||
vagrant plugin install vagrant-vbguest
|
||||
vagrant up
|
||||
```
|
||||
|
||||
Once the Vagrant machine is up and provisioned, you can access LANraragi at [http://localhost:3000](http://localhost:3000).
|
||||
Archives you upload will be placed in the directory of the Vagrantfile.
|
||||
|
||||
The Vagrant machine is a simple Docker wrapper, so the database will also be stored in this directory. (As database.rdb)
|
||||
|
||||
You can use `vagrant halt` to stop the VM when you're done.
|
||||
To start it up again, use the following commands:
|
||||
|
||||
```
|
||||
vagrant up
|
||||
vagrant provision
|
||||
```
|
||||
|
||||
Keep in mind that the Vagrant setup, just like Docker, will always use the latest release.
|
||||
|
||||
## Updating
|
||||
|
||||
From the directory where the Vagrantfile is located:
|
||||
|
||||
```bash
|
||||
vagrant up
|
||||
vagrant provision
|
||||
```
|
||||
|
||||
Those two commands will update the wrapped Docker image to the latest one(basically automatically doing the commands written up there on the Docker section). No other operations are needed.
|
@ -2,12 +2,22 @@
|
||||
|
||||
## Download a Release
|
||||
|
||||
You can directly install LANraragi from the [Microsoft Store](https://cutt.ly/9TJIMC6). This will install the latest release.
|
||||
|
||||
[<img src="https://getbadgecdn.azureedge.net/images/English_L.png">](https://cutt.ly/9TJIMC6)
|
||||
|
||||
You can directly install LANraragi from the Microsoft Store, using either this link: (paste in a browser window)
|
||||
ms-windows-store://pdp/?productid=XP9K4NMNPDMH6L
|
||||
|
||||
Or through winget:
|
||||
|
||||
```
|
||||
winget install lanraragi
|
||||
```
|
||||
|
||||
{% hint style="warning" %}
|
||||
The installer will tell you about this anyways, but LRR for Windows **requires** the Windows Subsystem for Linux to function properly.
|
||||
Read the tutorial [here](https://docs.microsoft.com/en-us/windows/wsl/install) to see how to enable WSL on your Windows 10 machine.
|
||||
WSL defaults to WSL2, so if the installer doesn't work properly make sure you have virtualization enabled as well, or switch to WSL1. (`wsl --set-default-version 1`)
|
||||
|
||||
You don't need to install a distribution through the Windows Store, as that is handled by the LRR installer package.
|
||||
{% endhint %}
|
||||
|
||||
As an alternative, you can always download the latest Windows MSI Installer on the [Release Page](https://github.com/Difegue/LANraragi/releases).
|
||||
|
||||
@ -23,44 +33,13 @@ You might get a SmartScreen prompt from Windows (doesn't seem to happen with the
|
||||
(If you're wondering why I don't sign installers, [this](https://gaby.dev/posts/code-signing) article is a good read.)
|
||||
|
||||
{% hint style="info" %}
|
||||
MS Store installs will be installed to the default location. If you don't want the app to install in _%AppData%_, consider downloading the installer and running it manually.
|
||||
{% endhint %}
|
||||
|
||||
|
||||
|
||||
{% hint style="warning" %}
|
||||
The installer will tell you about this anyways, but LRR for Windows **requires** the Windows Subsystem for Linux to function properly.
|
||||
Read the tutorial [here](https://docs.microsoft.com/en-us/windows/wsl/install) to see how to enable WSL on your Windows 10 machine.
|
||||
|
||||
You don't need to install a distribution through the Windows Store, as that is handled by the LRR installer package.
|
||||
MS Store/winget installs will be installed to the default location. If you don't want the app to install in _%AppData%_, consider downloading the installer and running it manually.
|
||||
{% endhint %}
|
||||
|
||||
Once the install completes properly, you'll be able to launch the GUI from the shortcut in your Start Menu:
|
||||
|
||||
![](../.screenshots/karen-startmenu.png)
|
||||
|
||||
## Installation on Windows 10 1809 (LTSC)
|
||||
|
||||
Recent MSI packages don't install on 1809 anymore due to underlying changes to make the installer lighter, but you can still sideload the latest server version on top of an old 0.7.9 install.
|
||||
|
||||
{% hint style="warning" %}
|
||||
This method shouldn't break in the foreseeable future, but as the Win32 bootstrapper will still be the 0.7.9 version, you might lose out on future functionalities later on.
|
||||
You might want to consider switching to a [source install](./source.md) on top of a Debian WSL distro you'd maintain yourself.
|
||||
{% endhint %}
|
||||
|
||||
1. Install 0.7.9 like normal, this is mostly done to get the Win32 UI application installed on to your taskbar, we'll install the updated Linux image next.
|
||||
2. If you started the service and the Windows application, make sure to close BOTH.
|
||||
3. Download the [MSI installer for the latest version](https://github.com/Difegue/LANraragi/releases/latest)
|
||||
4. Open the MSI file in 7zip, and extract the "package.tar" file, which is the underlying Linux image
|
||||
5. Download [LxRunOffline](https://github.com/DDoSolitary/LxRunOffline/releases) and put it in the same directory as the "package.tar" file you just extracted
|
||||
6. Uninstall the old Linux image from 0.7.9 with the following command, make sure to have your command window opened as administrator:
|
||||
`lxrunoffline ui -n lanraragi`
|
||||
7. install the new image:
|
||||
`lxrunoffline i -n lanraragi -d "C:\Users\*your user name*\AppData\Roaming\LANraragi\Distro\rootfs" -f LANraragi.tar`
|
||||
Note: the name of the install HAS to be "lanraragi", do not change this on the -n argument
|
||||
8. Start the application again, and you should see that it now shows the newest version of the server
|
||||
|
||||
|
||||
## Configuration
|
||||
|
||||
Starting the GUI for the first time will prompt you to setup your content folder and the port you want the server to listen on. The main GUI is always available from your Taskbar.
|
||||
|
@ -24,7 +24,7 @@ Basically, _as long as it can run, it will run_.
|
||||
{% hint style="danger" %}
|
||||
As you might've guessed, Plugins run with the same permissions as the main application.
|
||||
This means they can modify the application database at will, delete files, and execute system commands.
|
||||
None of this is obviously an issue if the application is installed in a proper fashion.(Docker/Vagrant, or non-root user on Linux _I seriously hope you guys don't run this as root_)
|
||||
None of this is obviously an issue if the application is installed in a proper fashion.(Docker/VM, or non-root user on Linux _I seriously hope you guys don't run this as root_)
|
||||
|
||||
Still, as said in the User Documentation, be careful of what you do with Plugins.
|
||||
{% endhint %}
|
||||
@ -69,7 +69,7 @@ The `type` field can be either:
|
||||
|
||||
* `login` for [Login Plugins](login.md)
|
||||
* `metadata` for [Metadata Plugins](metadata.md)
|
||||
* `download` for [Downloader Plugins](downloaders.md)
|
||||
* `download` for [Downloader Plugins](download.md)
|
||||
* `script` for [Script Plugins](scripts.md)
|
||||
|
||||
The `parameters` array can contain as many arguments as you need. They can be set by the user in Plugin Configuration, and are transmitted every time.
|
||||
|
@ -24,6 +24,7 @@ The variables match the parameters you've entered in the `plugin_info` subroutin
|
||||
|
||||
The `$lrr_info` hash contains various variables you can use in your plugin:
|
||||
|
||||
* _$lrr\_info->{archive\_id}_: The internal ID of the archive.
|
||||
* _$lrr\_info->{archive\_title}_: The title of the archive, as entered by the User.
|
||||
* _$lrr\_info->{existing\_tags}_: The tags that are already in LRR for this archive, if there are any.
|
||||
* _$lrr\_info->{thumbnail\_hash}_: A SHA-1 hash of the first image of the archive.
|
||||
|
@ -1,8 +1,7 @@
|
||||
# DOCKER-VERSION 0.3.4
|
||||
FROM alpine:3.12
|
||||
FROM alpine:3.16
|
||||
LABEL git="https://github.com/Difegue/LANraragi"
|
||||
|
||||
ENV S6_OVERLAY_RELEASE v2.0.0.1
|
||||
ENV S6_KEEP_ENV 1
|
||||
|
||||
# warn if we can't run stage2 (fix-attrs/cont-init)
|
||||
@ -10,9 +9,11 @@ ENV S6_BEHAVIOUR_IF_STAGE2_FAILS 1
|
||||
|
||||
# wait 10s before KILLing
|
||||
ENV S6_KILL_GRACETIME 10000
|
||||
ENV S6_CMD_WAIT_FOR_SERVICES_MAXTIME 0
|
||||
|
||||
# s6
|
||||
ENTRYPOINT ["/init"]
|
||||
# s6: The init is provided by alpine's s6-overlay package, hence the double slash.
|
||||
# See https://pkgs.alpinelinux.org/contents?branch=v3.14&name=s6-overlay&arch=x86&repo=community
|
||||
ENTRYPOINT ["//init"]
|
||||
|
||||
# Check application health
|
||||
HEALTHCHECK --interval=1m --timeout=10s --retries=3 \
|
||||
@ -22,14 +23,14 @@ HEALTHCHECK --interval=1m --timeout=10s --retries=3 \
|
||||
#Default mojo server port
|
||||
EXPOSE 3000
|
||||
|
||||
#Enable UTF-8 (might not do anything extra on alpine tho)
|
||||
# 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
|
||||
# rootless user id
|
||||
LRR_UID=9001 LRR_GID=9001 \
|
||||
#Environment variables overridable by the user on container deployment
|
||||
# Environment variables overridable by the user on container deployment
|
||||
LRR_NETWORK=http://*:3000 \
|
||||
# extra variables
|
||||
EV_EXTRA_DEFS=-DEV_NO_ATFORK
|
||||
EV_EXTRA_DEFS=-DEV_NO_ATFORK \
|
||||
# Enable automatic http proxy detection for mojo
|
||||
MOJO_PROXY=1 \
|
||||
# Allow Mojo to automatically pick up the X-Forwarded-For and X-Forwarded-Proto headers
|
||||
@ -43,15 +44,7 @@ RUN \
|
||||
adduser -D -u ${LRR_UID} -G koyomi koyomi; \
|
||||
fi
|
||||
|
||||
|
||||
# we use s6-overlay-nobin to just pull in the s6-overlay arch agnostic (shell)
|
||||
# components, since we apk install the binaries of s6 later which are arch specific
|
||||
# /!\ While the s6 version here is fixed by an envvar, the apk install is not pinned and takes whatever's in alpine:latest! This certainly needs a fix.
|
||||
ADD https://github.com/just-containers/s6-overlay/releases/download/${S6_OVERLAY_RELEASE}/s6-overlay-nobin.tar.gz /tmp/s6-overlay-nobin.tar.gz
|
||||
RUN tar -C / -xzf /tmp/s6-overlay-nobin.tar.gz && rm -f /tmp/s6-overlay-nobin.tar.gz
|
||||
|
||||
|
||||
WORKDIR /root/lanraragi
|
||||
WORKDIR /home/koyomi/lanraragi
|
||||
|
||||
#Copy cpanfile and install script before copying the entire context
|
||||
#This allows for Docker cache to preserve cpan dependencies
|
||||
@ -60,7 +53,7 @@ COPY --chown=koyomi:koyomi /package.json package.json
|
||||
|
||||
# Run the install script as root
|
||||
RUN sh ./tools/install-everything.sh
|
||||
|
||||
RUN rm -f /root/lanraragi/public/js/vendor/jquery.dataTables.min.js
|
||||
#Copy remaining LRR files from context
|
||||
COPY --chown=koyomi:koyomi /lib lib
|
||||
COPY --chown=koyomi:koyomi /public public
|
||||
@ -70,10 +63,14 @@ COPY --chown=koyomi:koyomi /tests tests
|
||||
COPY --chown=koyomi:koyomi /lrr.conf lrr.conf
|
||||
COPY --chown=koyomi:koyomi /tools/build/docker/redis.conf tools/build/docker/
|
||||
COPY /tools/build/docker/wsl.conf /etc/wsl.conf
|
||||
COPY /tools/build/docker/s6/cont-init.d/ /etc/cont-init.d/
|
||||
COPY /tools/build/docker/s6/services.d/ /etc/services.d/
|
||||
#Copy s6-overlay 3.x services
|
||||
#Uses a system-d like definition that can't be use in 2.x
|
||||
COPY /tools/build/docker/s6/s6-rc.d/ /etc/s6-overlay/s6-rc.d/
|
||||
#Copy setup script as-is since no changes are needed between 2.x and 3.x
|
||||
COPY /tools/build/docker/s6/cont-init.d/01-lrr-setup /etc/s6-overlay/s6-rc.d/init/
|
||||
COPY --chown=root:root /jquery.dataTables.min.js /root/lanraragi/public/js/vendor/jquery.dataTables.min.js
|
||||
#COPY /tools/build/docker/s6/fix-attrs.d/ /etc/fix-attrs.d/
|
||||
|
||||
# Persistent volumes
|
||||
VOLUME [ "/root/lanraragi/content" ]
|
||||
VOLUME [ "/root/lanraragi/database"]
|
||||
VOLUME [ "/home/koyomi/lanraragi/content" ]
|
||||
VOLUME [ "/home/koyomi/lanraragi/database"]
|
||||
|
75
tools/build/docker/Dockerfile-legacy
Normal file
75
tools/build/docker/Dockerfile-legacy
Normal file
@ -0,0 +1,75 @@
|
||||
# DOCKER-VERSION 0.3.4
|
||||
FROM alpine:3.12.12
|
||||
LABEL git="https://github.com/Difegue/LANraragi"
|
||||
|
||||
ENV S6_KEEP_ENV 1
|
||||
|
||||
# warn if we can't run stage2 (fix-attrs/cont-init)
|
||||
ENV S6_BEHAVIOUR_IF_STAGE2_FAILS 1
|
||||
|
||||
# wait 10s before KILLing
|
||||
ENV S6_KILL_GRACETIME 10000
|
||||
|
||||
# s6
|
||||
ENTRYPOINT ["/init"]
|
||||
|
||||
# Check application health
|
||||
HEALTHCHECK --interval=1m --timeout=10s --retries=3 \
|
||||
CMD wget --quiet --tries=1 --no-check-certificate --spider \
|
||||
http://localhost:3000 || exit 1
|
||||
|
||||
#Default mojo server port
|
||||
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=9001 LRR_GID=9001 \
|
||||
# Environment variables overridable by the user on container deployment
|
||||
LRR_NETWORK=http://*:3000 \
|
||||
# extra variables
|
||||
EV_EXTRA_DEFS=-DEV_NO_ATFORK \
|
||||
# Enable automatic http proxy detection for mojo
|
||||
MOJO_PROXY=1 \
|
||||
# Allow Mojo to automatically pick up the X-Forwarded-For and X-Forwarded-Proto headers
|
||||
MOJO_REVERSE_PROXY=1
|
||||
|
||||
RUN \
|
||||
if [ $(getent group ${LRR_GID}) ]; then \
|
||||
adduser -D -u ${LRR_UID} koyomi; \
|
||||
else \
|
||||
addgroup -g ${LRR_GID} koyomi && \
|
||||
adduser -D -u ${LRR_UID} -G koyomi koyomi; \
|
||||
fi
|
||||
|
||||
# we use s6-overlay-nobin to just pull in the s6-overlay arch agnostic (shell)
|
||||
# components, since we apk install the binaries of s6 later which are arch specific
|
||||
ADD https://github.com/just-containers/s6-overlay/releases/download/v2.0.0.1/s6-overlay-nobin.tar.gz /tmp/s6-overlay-nobin.tar.gz
|
||||
RUN tar -C / -xzf /tmp/s6-overlay-nobin.tar.gz && rm -f /tmp/s6-overlay-nobin.tar.gz
|
||||
|
||||
WORKDIR /home/koyomi/lanraragi
|
||||
|
||||
#Copy cpanfile and install script before copying the entire context
|
||||
#This allows for Docker cache to preserve cpan dependencies
|
||||
COPY --chown=koyomi:koyomi /tools/cpanfile /tools/install.pl /tools/build/docker/install-everything.sh tools/
|
||||
COPY --chown=koyomi:koyomi /package.json package.json
|
||||
|
||||
# Run the install script as root
|
||||
RUN sh ./tools/install-everything.sh
|
||||
|
||||
#Copy remaining LRR files from context
|
||||
COPY --chown=koyomi:koyomi /lib lib
|
||||
COPY --chown=koyomi:koyomi /public public
|
||||
COPY --chown=koyomi:koyomi /script script
|
||||
COPY --chown=koyomi:koyomi /templates templates
|
||||
COPY --chown=koyomi:koyomi /tests tests
|
||||
COPY --chown=koyomi:koyomi /lrr.conf lrr.conf
|
||||
COPY --chown=koyomi:koyomi /tools/build/docker/redis.conf tools/build/docker/
|
||||
COPY /tools/build/docker/wsl.conf /etc/wsl.conf
|
||||
COPY /tools/build/docker/s6/cont-init.d/ /etc/cont-init.d/
|
||||
COPY /tools/build/docker/s6/legacy-services.d/ /etc/services.d/
|
||||
#COPY /tools/build/docker/s6/fix-attrs.d/ /etc/fix-attrs.d/
|
||||
|
||||
# Persistent volumes
|
||||
VOLUME [ "/home/koyomi/lanraragi/content" ]
|
||||
VOLUME [ "/home/koyomi/lanraragi/database"]
|
@ -3,7 +3,7 @@
|
||||
#Just do everything
|
||||
apk update
|
||||
apk add tzdata
|
||||
apk add perl perl-io-socket-ssl perl-dev redis libarchive-dev libbz2 openssl-dev zlib-dev
|
||||
apk add perl perl-io-socket-ssl perl-dev redis libarchive-dev libbz2 openssl-dev zlib-dev linux-headers
|
||||
apk add imagemagick imagemagick-perlmagick libwebp-tools libheif
|
||||
apk add g++ make pkgconf gnupg wget curl file
|
||||
apk add shadow s6 s6-portable-utils
|
||||
@ -14,7 +14,7 @@ if [ -f /etc/alpine-release ]; then
|
||||
if [ "$alpine_version" = "3.12.12" ]; then
|
||||
apk add nodejs-npm
|
||||
else # Those packages don't exist on 3.12
|
||||
apk add nodejs npm s6-overlay s6-overlay-preinit
|
||||
apk add nodejs npm s6-overlay libjxl
|
||||
fi
|
||||
fi
|
||||
|
||||
@ -24,12 +24,14 @@ curl -L https://cpanmin.us | perl - App::cpanminus
|
||||
#Alpine's libffi build comes with AVX instructions enabled
|
||||
#Rebuild our own libffi with those disabled
|
||||
if [ $(uname -m) == 'x86_64' ]; then
|
||||
|
||||
#Install deps only
|
||||
cpanm --notest --installdeps Alien::FFI
|
||||
curl -L -s https://cpan.metacpan.org/authors/id/P/PL/PLICEASE/Alien-FFI-0.25.tar.gz | tar -xz
|
||||
cd Alien-FFI-0.25
|
||||
#Patch build script to disable AVX
|
||||
sed -i 's/--disable-builddir/--disable-builddir --with-gcc-arch=x86-64-v2/' alienfile
|
||||
# Patch build script to disable AVX - and SSE4 for real old CPUs
|
||||
# See https://developers.redhat.com/blog/2021/01/05/building-red-hat-enterprise-linux-9-for-the-x86-64-v2-microarchitecture-level
|
||||
sed -i 's/--disable-builddir/--disable-builddir --with-gcc-arch=x86-64/' alienfile
|
||||
perl Makefile.PL && make install
|
||||
cd ../ && rm -rf Alien-FFI-0.25
|
||||
fi
|
||||
|
@ -168,7 +168,7 @@ loglevel notice
|
||||
# Specify the log file name. Also the empty string can be used to force
|
||||
# Redis to log on the standard output. Note that if you use standard
|
||||
# output for logging but daemonize, logs will be sent to /dev/null
|
||||
logfile /root/lanraragi/log/redis.log
|
||||
logfile /home/koyomi/lanraragi/log/redis.log
|
||||
|
||||
# To enable logging to the system logger, just set 'syslog-enabled' to yes,
|
||||
# and optionally update the other syslog parameters to suit your needs.
|
||||
@ -259,7 +259,7 @@ dbfilename database.rdb
|
||||
# The Append Only File will also be created inside this directory.
|
||||
#
|
||||
# Note that you must specify a directory here, not a file name.
|
||||
dir /root/lanraragi/database
|
||||
dir /home/koyomi/lanraragi/database
|
||||
|
||||
################################# REPLICATION #################################
|
||||
|
||||
|
@ -1,40 +1,50 @@
|
||||
#!/bin/sh
|
||||
|
||||
USER_ID=${LRR_UID}
|
||||
GROUP_ID=${LRR_GID}
|
||||
|
||||
echo "Starting LANraragi with UID/GID : $USER_ID/$GROUP_ID"
|
||||
|
||||
#Update the koyomi user, using the specified uid/gid.
|
||||
#This solves permission problems on the content folder if the Docker user sets the same uid as the owner of the folder.
|
||||
usermod -o -u $USER_ID koyomi
|
||||
groupmod -o -g $GROUP_ID koyomi
|
||||
|
||||
#Ensure LRR folder is writable
|
||||
chown root /root/lanraragi
|
||||
chmod u+rwx /root/lanraragi
|
||||
chown koyomi /home/koyomi/lanraragi
|
||||
chmod u+rwx /home/koyomi/lanraragi
|
||||
|
||||
#Crash with an error if content folder doesn't exist
|
||||
if [ ! -d "/root/lanraragi/content" ]; then
|
||||
if [ ! -d "/home/koyomi/lanraragi/content" ]; then
|
||||
echo "Content folder doesn't exist! Please ensure your Docker mappings are correct."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
#Ensure database is writable
|
||||
chown -R root /root/lanraragi/database
|
||||
chmod -R 777 /root/lanraragi/database
|
||||
chown -R koyomi /home/koyomi/lanraragi/database
|
||||
chmod -R u+rwx /home/koyomi/lanraragi/database
|
||||
|
||||
#Ensure thumbnail folder is writable
|
||||
chmod -R 744 /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 {} \;
|
||||
chown -R koyomi /home/koyomi/lanraragi/content/thumb
|
||||
find /home/koyomi/lanraragi/content/thumb -type f -exec chmod u+rw {} \;
|
||||
find /home/koyomi/lanraragi/content/thumb -type d -exec chmod u+rwx {} \;
|
||||
|
||||
#Ensure log folder is writable
|
||||
mkdir /root/lanraragi/log
|
||||
chown -R root /root/lanraragi/log
|
||||
chmod u+rwx /root/lanraragi/log
|
||||
mkdir /home/koyomi/lanraragi/log
|
||||
chown -R koyomi /home/koyomi/lanraragi/log
|
||||
chmod u+rwx /home/koyomi/lanraragi/log
|
||||
|
||||
#Ensure temp folder is writable
|
||||
mkdir /root/lanraragi/public/temp
|
||||
chown -R root /root/lanraragi/public/temp
|
||||
chmod u+rwx /root/lanraragi/public/temp
|
||||
mkdir /home/koyomi/lanraragi/public/temp
|
||||
chown -R koyomi /home/koyomi/lanraragi/public/temp
|
||||
chmod u+rwx /home/koyomi/lanraragi/public/temp
|
||||
|
||||
#Remove mojo, minion and shinobu pid files
|
||||
rm /root/lanraragi/public/temp/server.pid
|
||||
rm /root/lanraragi/public/temp/shinobu.pid
|
||||
rm /root/lanraragi/public/temp/minion.pid
|
||||
rm /home/koyomi/lanraragi/public/temp/server.pid
|
||||
rm /home/koyomi/lanraragi/public/temp/shinobu.pid
|
||||
rm /home/koyomi/lanraragi/public/temp/shinobu.pid-s6
|
||||
rm /home/koyomi/lanraragi/public/temp/minion.pid
|
||||
rm /home/koyomi/lanraragi/public/temp/minion.pid-s6
|
||||
|
||||
# https://redis.io/topics/faq#background-saving-fails-with-a-fork-error-under-linux-even-if-i-have-a-lot-of-free-ram
|
||||
OVERCOMMIT=$(cat /proc/sys/vm/overcommit_memory)
|
||||
|
@ -1,7 +1,8 @@
|
||||
# Currently unused, see Dockerfile
|
||||
# second field in user is fallback uid
|
||||
# path recurse user fperm dperm
|
||||
/root/lanraragi false root,0:0 0644 0744
|
||||
/root/lanraragi/database true root,0:0 0777 0777
|
||||
/root/lanraragi/content/thumb true root,0:0 0644 0744
|
||||
/root/lanraragi/log false root,0:0 0644 0744
|
||||
/root/lanraragi/public/temp false root,0:0 0644 0744
|
||||
/home/koyomi/lanraragi false koyomi,9001:9001 0644 0744
|
||||
/home/koyomi/lanraragi/database true koyomi,9001:9001 0777 0777
|
||||
/home/koyomi/lanraragi/content/thumb true koyomi,9001:9001 0644 0744
|
||||
/home/koyomi/lanraragi/log false koyomi,9001:9001 0644 0744
|
||||
/home/koyomi/lanraragi/public/temp false koyomi,9001:9001 0644 0744
|
||||
|
4
tools/build/docker/s6/legacy-services.d/lanraragi/run
Normal file
4
tools/build/docker/s6/legacy-services.d/lanraragi/run
Normal file
@ -0,0 +1,4 @@
|
||||
#!/bin/sh
|
||||
cd /home/koyomi/lanraragi/
|
||||
export HOME=/home/koyomi
|
||||
s6-setuidgid koyomi perl /home/koyomi/lanraragi/script/launcher.pl -f /home/koyomi/lanraragi/script/lanraragi
|
2
tools/build/docker/s6/legacy-services.d/redis/run
Normal file
2
tools/build/docker/s6/legacy-services.d/redis/run
Normal file
@ -0,0 +1,2 @@
|
||||
#!/bin/sh
|
||||
s6-setuidgid koyomi /usr/bin/redis-server /home/koyomi/lanraragi/tools/build/docker/redis.conf
|
1
tools/build/docker/s6/s6-rc.d/init/type
Normal file
1
tools/build/docker/s6/s6-rc.d/init/type
Normal file
@ -0,0 +1 @@
|
||||
oneshot
|
1
tools/build/docker/s6/s6-rc.d/init/up
Normal file
1
tools/build/docker/s6/s6-rc.d/init/up
Normal file
@ -0,0 +1 @@
|
||||
/etc/s6-overlay/s6-rc.d/init/01-lrr-setup
|
4
tools/build/docker/s6/s6-rc.d/lanraragi/finish
Normal file
4
tools/build/docker/s6/s6-rc.d/lanraragi/finish
Normal file
@ -0,0 +1,4 @@
|
||||
#!/bin/sh
|
||||
kill -15 `cat /home/koyomi/lanraragi/public/temp/shinobu.pid-s6`
|
||||
kill -15 `cat /home/koyomi/lanraragi/public/temp/minion.pid-s6`
|
||||
sleep 5
|
4
tools/build/docker/s6/s6-rc.d/lanraragi/run
Normal file
4
tools/build/docker/s6/s6-rc.d/lanraragi/run
Normal file
@ -0,0 +1,4 @@
|
||||
#!/bin/sh
|
||||
cd /home/koyomi/lanraragi/
|
||||
export HOME=/home/koyomi
|
||||
exec s6-setuidgid koyomi perl /home/koyomi/lanraragi/script/launcher.pl -f /home/koyomi/lanraragi/script/lanraragi
|
1
tools/build/docker/s6/s6-rc.d/lanraragi/type
Normal file
1
tools/build/docker/s6/s6-rc.d/lanraragi/type
Normal file
@ -0,0 +1 @@
|
||||
longrun
|
2
tools/build/docker/s6/s6-rc.d/redis/run
Normal file
2
tools/build/docker/s6/s6-rc.d/redis/run
Normal file
@ -0,0 +1,2 @@
|
||||
#!/bin/sh
|
||||
exec s6-setuidgid koyomi /usr/bin/redis-server /home/koyomi/lanraragi/tools/build/docker/redis.conf
|
1
tools/build/docker/s6/s6-rc.d/redis/type
Normal file
1
tools/build/docker/s6/s6-rc.d/redis/type
Normal file
@ -0,0 +1 @@
|
||||
longrun
|
0
tools/build/docker/s6/s6-rc.d/user/contents.d/init
Normal file
0
tools/build/docker/s6/s6-rc.d/user/contents.d/init
Normal file
0
tools/build/docker/s6/s6-rc.d/user/contents.d/redis
Normal file
0
tools/build/docker/s6/s6-rc.d/user/contents.d/redis
Normal file
@ -1,4 +0,0 @@
|
||||
#!/bin/sh
|
||||
cd /root/lanraragi/
|
||||
export HOME=/root
|
||||
perl /root/lanraragi/script/launcher.pl -f /root/lanraragi/script/lanraragi
|
@ -1,2 +0,0 @@
|
||||
#!/bin/sh
|
||||
/usr/bin/redis-server /root/lanraragi/tools/build/docker/redis.conf
|
2
tools/build/vagrant/.gitignore
vendored
2
tools/build/vagrant/.gitignore
vendored
@ -1,2 +0,0 @@
|
||||
.vagrant
|
||||
database.rdb
|
22
tools/build/vagrant/Vagrantfile
vendored
22
tools/build/vagrant/Vagrantfile
vendored
@ -1,22 +0,0 @@
|
||||
# -*- mode: ruby -*-
|
||||
# vi: set ft=ruby :
|
||||
|
||||
# All Vagrant configuration is done below. The "2" in Vagrant.configure
|
||||
# configures the configuration version (we support older styles for
|
||||
# backwards compatibility). Please don't change it unless you know what
|
||||
# you're doing.
|
||||
Vagrant.configure(2) do |config|
|
||||
|
||||
config.vm.box = "debian/jessie64"
|
||||
config.vm.network :forwarded_port, guest: 3000, host: 3000
|
||||
config.vm.synced_folder ".", "/vagrant", type: "virtualbox"
|
||||
config.vm.provision "shell",
|
||||
inline: "docker stop lanraragi || true && docker rm lanraragi || true"
|
||||
config.vm.provision "docker" do |d|
|
||||
d.pull_images "difegue/lanraragi:latest"
|
||||
d.run "difegue/lanraragi:latest",
|
||||
args: "--name=lanraragi -e LRR_UID=1000 -p 3000:3000 --restart=always --mount type=bind,source=/vagrant,target=/root/lanraragi/content "
|
||||
end
|
||||
config.vm.post_up_message = "LANraragi Vagrant Machine Started, App should be available at http://localhost:3000."
|
||||
|
||||
end
|
@ -1,22 +0,0 @@
|
||||
# -*- mode: ruby -*-
|
||||
# vi: set ft=ruby :
|
||||
|
||||
# All Vagrant configuration is done below. The "2" in Vagrant.configure
|
||||
# configures the configuration version (we support older styles for
|
||||
# backwards compatibility). Please don't change it unless you know what
|
||||
# you're doing.
|
||||
Vagrant.configure(2) do |config|
|
||||
|
||||
config.vm.box = "debian/jessie64"
|
||||
config.vm.network :forwarded_port, guest: 3000, host: 3000
|
||||
config.vm.synced_folder ".", "/vagrant", type: "virtualbox"
|
||||
config.vm.provision "shell",
|
||||
inline: "docker stop lanraragi || true && docker rm lanraragi || true"
|
||||
config.vm.provision "docker" do |d|
|
||||
d.pull_images "difegue/lanraragi"
|
||||
d.run "difegue/lanraragi:nightly",
|
||||
args: "--name=lanraragi -e LRR_UID=1000 -p 3000:3000 --restart=always --mount type=bind,source=/vagrant,target=/root/lanraragi/content "
|
||||
end
|
||||
config.vm.post_up_message = "LANraragi Vagrant Machine Started, App should be available at http://localhost:3000."
|
||||
|
||||
end
|
@ -1,22 +0,0 @@
|
||||
# --- LRR Windows build script ---
|
||||
|
||||
echo "🎌 Building up LRR Windows Package 🎌"
|
||||
echo "Inferring version from package.json..."
|
||||
|
||||
$json = (Get-Content "package.json" -Raw) | ConvertFrom-Json
|
||||
$version = $json.version
|
||||
echo "Version is $version"
|
||||
$env:LRR_VERSION_NUM=$version
|
||||
|
||||
# Use Docker image
|
||||
mv .\package\package.tar .\tools\build\windows\Karen\External\package.tar
|
||||
|
||||
# Use Karen master
|
||||
cd .\tools\build\windows\Karen
|
||||
echo (Resolve-Path .\).Path
|
||||
nuget restore
|
||||
|
||||
# Build Karen and Setup
|
||||
msbuild /p:Configuration=Release
|
||||
|
||||
Get-FileHash .\Setup\bin\LANraragi.msi | Format-List
|
@ -6,7 +6,7 @@ requires 'local::lib', 2.000024;
|
||||
requires 'Redis', 1.995;
|
||||
requires 'Encode', 3.01;
|
||||
requires 'Archive::Libarchive::Extract', 0.03;
|
||||
requires 'Archive::Libarchive::Peek', 0.03;
|
||||
requires 'Archive::Libarchive::Peek', 0.04;
|
||||
requires 'Digest::SHA', 6.02;
|
||||
|
||||
# Not required by LRR itself but needs this version for Alpine support
|
||||
@ -36,7 +36,7 @@ requires 'Test::Trap', 0.3.4;
|
||||
requires 'Test::Deep', 1.130;
|
||||
|
||||
# Mojo stuff
|
||||
requires 'Mojolicious', 9.19;
|
||||
requires 'Mojolicious', 9.27;
|
||||
requires 'Mojolicious::Plugin::TemplateToolkit', 0.005;
|
||||
requires 'Mojolicious::Plugin::RenderFile', 0.12;
|
||||
requires 'Mojolicious::Plugin::Status', 1.15;
|
||||
@ -44,7 +44,7 @@ requires 'IO::Socket::SSL', 2.067;
|
||||
requires 'Cpanel::JSON::XS', 4.06;
|
||||
|
||||
# Job Queue (Minion)
|
||||
requires 'Minion', 10.20;
|
||||
requires 'Minion', 10.25;
|
||||
requires 'Minion::Backend::Redis', 0.002;
|
||||
|
||||
# Background Worker (Shinobu)
|
||||
|
BIN
tools/logo.png
BIN
tools/logo.png
Binary file not shown.
Before Width: | Height: | Size: 8.3 KiB |
Loading…
Reference in New Issue
Block a user