diff --git a/qbittorrent/CHANGELOG.md b/qbittorrent/CHANGELOG.md new file mode 100644 index 000000000..e69de29bb diff --git a/qbittorrent/Dockerfile b/qbittorrent/Dockerfile new file mode 100644 index 000000000..90c92f648 --- /dev/null +++ b/qbittorrent/Dockerfile @@ -0,0 +1,33 @@ +ARG BUILD_FROM +# hadolint ignore=DL3006 +FROM $BUILD_FROM + +# Set shell +SHELL ["/bin/bash", "-o", "pipefail", "-c"] + +RUN apt-get update \ + \ + && apt-get install -y --no-install-recommends \ + jq=1.5+dfsg-2 \ + \ + && apt-get -y upgrade cifs-utils \ + && curl -J -L -o /tmp/bashio.tar.gz \ + "https://github.com/hassio-addons/bashio/archive/v0.7.1.tar.gz" \ + && mkdir /tmp/bashio \ + && tar zxvf \ + /tmp/bashio.tar.gz \ + --strip 1 -C /tmp/bashio \ + \ + && mv /tmp/bashio/lib /usr/lib/bashio \ + && ln -s /usr/lib/bashio/bashio /usr/bin/bashio \ + && rm -fr \ + /tmp/* \ + /var/{cache,log}/* \ + /var/lib/apt/lists/* + +# copy local files +COPY root/ / + +RUN sed -i "s|/config|/qbittorrent|g" /etc/services.d/qbittorrent/run \ + && sed -i "s|/config|/qbittorrent|g" /etc/cont-init.d/30-config + diff --git a/qbittorrent/README.md b/qbittorrent/README.md new file mode 100644 index 000000000..d39acb785 --- /dev/null +++ b/qbittorrent/README.md @@ -0,0 +1,27 @@ +# Hassio Add-ons by alexbelgium: qbittorrent + +## About + +[qbittorrent](https://qbittorrent.media/) project aims to provide an open-source software alternative to µTorrent. qBittorrent is based on the Qt toolkit and libtorrent-rasterbar library. + +This addon is based on the [docker image](https://github.com/linuxserver/docker-qbittorrent) from linuxserver.io. + +## Installation + +The installation of this add-on is pretty straightforward and not different in +comparison to installing any other Hass.io add-on. + +1. [Add my Hass.io add-ons repository][repository] to your Hass.io instance. +1. Install this add-on. +1. Click the `Save` button to store your configuration. +1. Start the add-on. +1. Check the logs of the add-on to see if everything went well. +1. Carefully configure the add-on to your preferences, see the official documentation for for that. + + +## Configuration + +Webui can be found at `:8096`. + + +[repository]: https://github.com/alexbelgium/hassio-addons diff --git a/qbittorrent/build.json b/qbittorrent/build.json new file mode 100644 index 000000000..c9b124c10 --- /dev/null +++ b/qbittorrent/build.json @@ -0,0 +1,14 @@ +{ + "build_from_template": { + "image": "linuxserver/qbittorrent", + "version": "beta" + }, + "build_from": { + "armv7": "linuxserver/qbittorrent:arm32v7-beta", + "armhf": "linuxserver/qbittorrent:arm32v7-beta", + "aarch64": "linuxserver/qbittorrent:arm64v8-beta", + "amd64": "linuxserver/qbittorrent:amd64-beta" + }, + "squash": false, + "args": {} +} diff --git a/qbittorrent/config.json b/qbittorrent/config.json new file mode 100644 index 000000000..0275d019c --- /dev/null +++ b/qbittorrent/config.json @@ -0,0 +1,52 @@ +{ + "name": "qbittorrent beta with smb and hdd", + "version": "1.0", + "slug": "qbittorrent_nas", + "legacy": false, + "maintenance": { + "github_release": "https://github.com/linuxserver/docker-qbittorrent", + "version_regex": "(\\d+\\.\\d+\\.\\d+.\\d+)-(ls\\d+)" + }, + "description": "A Free Software Media System that puts you in control of managing and streaming your media.", + "url": "https://github.com/alexbelgium/hassio-addons/tree/master/qbittorrent#readme", + "startup": "services", + "arch": [ + "aarch64", + "amd64", + "armv7", + "armhf" + ], + "ports": { + "8080/tcp": 8080 }, + "ports_description": { + "8080/tcp": "web interface" + }, + "map": [ + "config:rw", + "share:rw", + "media:rw", + "ssl" + ], + "webui": "http://[HOST]:[PORT:8080]", + "boot": "auto", + "privileged": ["SYS_ADMIN", "DAC_READ_SEARCH"], + "full_access": true, + "options": { + "PUID": 1001, + "PGID": 1001, + "localdisks": "/dev/sdb1", + "networkdisks": "", + "cifsusername": "", + "cifspassword": "" + }, + "schema": { + "PUID": "int", + "PGID": "int", + "TZ": "str?", + "localdisks": "str", + "networkdisks": "str", + "cifsusername": "str", + "cifspassword": "str" + } + +} diff --git a/qbittorrent/icon.png b/qbittorrent/icon.png new file mode 100644 index 000000000..fe71933da Binary files /dev/null and b/qbittorrent/icon.png differ diff --git a/qbittorrent/logo.png b/qbittorrent/logo.png new file mode 100644 index 000000000..fe71933da Binary files /dev/null and b/qbittorrent/logo.png differ diff --git a/qbittorrent/root/etc/cont-init.d/00-ha-env b/qbittorrent/root/etc/cont-init.d/00-ha-env new file mode 100644 index 000000000..3b3e69246 --- /dev/null +++ b/qbittorrent/root/etc/cont-init.d/00-ha-env @@ -0,0 +1,5 @@ +#!/usr/bin/with-contenv bashio + +for k in $(bashio::jq "${__BASHIO_ADDON_CONFIG}" 'keys | .[]'); do + printf "$(bashio::config $k)" > /var/run/s6/container_environment/$k +done \ No newline at end of file diff --git a/qbittorrent/root/etc/cont-init.d/20-folders b/qbittorrent/root/etc/cont-init.d/20-folders new file mode 100644 index 000000000..b5a4b3649 --- /dev/null +++ b/qbittorrent/root/etc/cont-init.d/20-folders @@ -0,0 +1,70 @@ +#!/usr/bin/with-contenv bash + +if [ ! -d /emby ]; then + echo "Creating /emby" + mkdir -p /emby + chown -R abc:abc /emby +fi + +if [ ! -d /share/emby ]; then + echo "Creating /share/emby" + mkdir -p /share/emby + chown -R abc:abc /share/emby +fi + +if [ ! -d /config/emby ]; then + echo "Creating /config/emby" + mkdir -p /config/emby + chown -R abc:abc /config/emby +fi + +# links + +if [ ! -d /emby/cache ]; then + echo "Creating link for /emby/cache" + mkdir -p /share/emby/cache + chown -R abc:abc /share/emby/cache + ln -s /share/emby/cache /emby/cache +fi + +if [ ! -d /emby/config ]; then + echo "Creating link for /emby/config" + mkdir -p /config/emby + chown -R abc:abc /config/emby + ln -s /config/emby /emby/config +fi + +if [ ! -d /emby/data ]; then + echo "Creating link for /emby/data" + mkdir -p /share/emby/data + chown -R abc:abc /share/emby/data + ln -s /share/emby/data /emby/data +fi + +if [ ! -d /emby/logs ]; then + echo "Creating link for /emby/logs" + mkdir -p /share/emby/logs + chown -R abc:abc /share/emby/logs + ln -s /share/emby/logs /emby/logs +fi + +if [ ! -d /emby/metadata ]; then + echo "Creating link for /emby/metadata" + mkdir -p /share/emby/metadata + chown -R abc:abc /share/emby/metadata + ln -s /share/emby/metadata /emby/metadata +fi + +if [ ! -d /emby/plugins ]; then + echo "Creating link for /emby/plugins" + mkdir -p /share/emby/plugins + chown -R abc:abc /share/emby/plugins + ln -s /share/emby/plugins /emby/plugins +fi + +if [ ! -d /emby/root ]; then + echo "Creating link for /emby/root" + mkdir -p /share/emby/root + chown -R abc:abc /share/emby/root + ln -s /share/emby/root /emby/root +fi diff --git a/qbittorrent/root/etc/cont-init.d/50-mounts b/qbittorrent/root/etc/cont-init.d/50-mounts new file mode 100644 index 000000000..ab6c54ec2 --- /dev/null +++ b/qbittorrent/root/etc/cont-init.d/50-mounts @@ -0,0 +1,46 @@ +#!/usr/bin/with-contenv bashio + +#!/usr/bin/with-contenv bashio +bashio::log.info 'Mounting external hdd...' + +# Mount local Share if configured and if Protection Mode is active +if bashio::config.has_value 'localdisks'; then + MOREDISKS=$(bashio::config 'localdisks') + bashio::log.info "Local Disks mounting.. ${MOREDISKS}" && \ + for disk in $MOREDISKS + do + bashio::log.info "Mount ${disk}" + mkdir -p /share/storage && \ + if [ ! -d /share/storage ]; then + echo "Creating /share/storage" + mkdir -p /share/storage + chown -R abc:abc /share/storage + fi + + mount $disk /share/storage && \ + bashio::log.info "Success!" + done || \ + bashio::log.warning "Protection mode is ON. Unable to mount local drives!" +fi + +# Mount CIFS Share if configured and if Protection Mode is active +if bashio::config.has_value 'networkdisks'; then + MOREDISKS=$(bashio::config 'networkdisks') + CIFS_USERNAME=$(bashio::config 'cifsusername') + CIFS_PASSWORD=$(bashio::config 'cifspassword') + bashio::log.info "Network Disks mounting.. ${MOREDISKS}" && \ + for disk in $MOREDISKS + do + bashio::log.info "Mount ${disk}" + mkdir -p /share/storagecifs && \ + if [ ! -d /share/storagecifs ]; then + echo "Creating /share/storagecifs" + mkdir -p /share/storagecifs + chown -R abc:abc /share/storagecifs + fi + + mount -t cifs -o username=$CIFS_USERNAME,password=$CIFS_PASSWORD $disk /share/storagecifs && \ + bashio::log.info "Success!" + done || \ + bashio::log.warning "Protection mode is ON. Unable to mount external drives!" +fi