mirror of
https://github.com/alexbelgium/hassio-addons.git
synced 2026-06-09 09:05:55 +02:00
initial upload
This commit is contained in:
11
joal/Dockerfile
Normal file
11
joal/Dockerfile
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
ARG BUILD_FROM
|
||||||
|
FROM $BUILD_FROM
|
||||||
|
|
||||||
|
# Copy root filesystem
|
||||||
|
COPY rootfs /
|
||||||
|
|
||||||
|
# MOFIFY DATA PATH
|
||||||
|
RUN sed -i "s|config|share/transmission|g" /etc/services.d/transmission/run \
|
||||||
|
&& sed -i "s|config|share/transmission|g" /etc/cont-init.d/20-config
|
||||||
|
|
||||||
|
VOLUME [ "/data" ]
|
||||||
39
joal/README.md
Normal file
39
joal/README.md
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
# Home assistant add-on: Transmission
|
||||||
|
![Supports aarch64 Architecture][aarch64-shield] ![Supports amd64 Architecture][amd64-shield] ![Supports armhf Architecture][armhf-shield] ![Supports armv7 Architecture][armv7-shield]
|
||||||
|
|
||||||
|
## About
|
||||||
|
|
||||||
|
Transmission is a bittorrent client.
|
||||||
|
This addon is based on the [docker image](https://github.com/linuxserver/transmission) 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
|
||||||
|
|
||||||
|
Options :
|
||||||
|
- "download_dir": "/share/downloads" # where the files will be saved after download
|
||||||
|
- "incomplete_dir": "/share/incomplete" # where the files are saved during download
|
||||||
|
- "localdisks": ["sda1"] # list of devices to mount, '' if none
|
||||||
|
- "networkdisks": "<//SERVER/SHARE>" # list of smbv2/3 servers to mount, '' if none
|
||||||
|
- "cifsusername": "<username>" # smb username
|
||||||
|
- "cifspassword": "<password>" # smb password
|
||||||
|
|
||||||
|
Complete transmission options are in /share/transmission (make sure addon is stopped before modifying it as Transmission writes its ongoing values when stopping and could erase your changes)
|
||||||
|
|
||||||
|
Webui can be found at `<your-ip>:9091`.
|
||||||
|
|
||||||
|
[repository]: https://github.com/alexbelgium/hassio-addons
|
||||||
|
[aarch64-shield]: https://img.shields.io/badge/aarch64-yes-green.svg
|
||||||
|
[amd64-shield]: https://img.shields.io/badge/amd64-yes-green.svg
|
||||||
|
[armhf-shield]: https://img.shields.io/badge/armhf-yes-green.svg
|
||||||
|
[armv7-shield]: https://img.shields.io/badge/armv7-yes-green.svg
|
||||||
11
joal/build.json
Normal file
11
joal/build.json
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
{
|
||||||
|
"build_from": {
|
||||||
|
"armv7": "anthonyraymond/joal:2.1.24-arm",
|
||||||
|
"armhf": "anthonyraymond/joal:2.1.24-arm",
|
||||||
|
"aarch64": "anthonyraymond/joal:2.1.24-arm64",
|
||||||
|
"amd64": "anthonyraymond/joal:2.1.24-amd64",
|
||||||
|
},
|
||||||
|
"squash": false,
|
||||||
|
"args": {}
|
||||||
|
}
|
||||||
|
|
||||||
50
joal/config.json
Normal file
50
joal/config.json
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
{
|
||||||
|
"name": "Joal Desktop test",
|
||||||
|
"version": "2.1.24",
|
||||||
|
"slug": "joal",
|
||||||
|
"description": "Joal Desktop docker".
|
||||||
|
"url": "https://github.com/alexbelgium/hassio-addons/tree/master/joal",
|
||||||
|
"startup": "services",
|
||||||
|
"arch": [
|
||||||
|
"aarch64",
|
||||||
|
"amd64",
|
||||||
|
"armv7",
|
||||||
|
"armhf"
|
||||||
|
],
|
||||||
|
"ports": {
|
||||||
|
"1234/tcp": 1234
|
||||||
|
},
|
||||||
|
"ports_description": {
|
||||||
|
"1234/tcp": "Web UI port (required),
|
||||||
|
},
|
||||||
|
"map": [
|
||||||
|
"share:rw"
|
||||||
|
],
|
||||||
|
"webui": "http://[HOST]:[PORT:1234]",
|
||||||
|
"boot": "auto",
|
||||||
|
"environment": {
|
||||||
|
"PUID": 0,
|
||||||
|
"PGID": 0
|
||||||
|
},
|
||||||
|
"options": {
|
||||||
|
"PUID": 0,
|
||||||
|
"PGID": 0,
|
||||||
|
"download_dir": "/share/downloads",
|
||||||
|
"incomplete_dir": "/share/incomplete",
|
||||||
|
"localdisks": ["sda1"],
|
||||||
|
"networkdisks": "//SERVER/SHARE",
|
||||||
|
"cifsusername": "username",
|
||||||
|
"cifspassword": "password"
|
||||||
|
},
|
||||||
|
"schema": {
|
||||||
|
"PUID": "int",
|
||||||
|
"PGID": "int",
|
||||||
|
"TZ": "str?",
|
||||||
|
"download_dir": "str",
|
||||||
|
"incomplete_dir": "str",
|
||||||
|
"localdisks": ["str?"],
|
||||||
|
"networkdisks": "str?",
|
||||||
|
"cifsusername": "str?",
|
||||||
|
"cifspassword": "str?"
|
||||||
|
}
|
||||||
|
}
|
||||||
BIN
joal/icon.png
Normal file
BIN
joal/icon.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 18 KiB |
BIN
joal/logo.png
Normal file
BIN
joal/logo.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 18 KiB |
30
joal/rootfs/etc/cont-init.d/20-transmission-configuration.sh
Normal file
30
joal/rootfs/etc/cont-init.d/20-transmission-configuration.sh
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
#!/usr/bin/with-contenv bashio
|
||||||
|
# ==============================================================================
|
||||||
|
|
||||||
|
declare CONFIG
|
||||||
|
declare incomplete_bool
|
||||||
|
declare download_dir
|
||||||
|
declare incomplete_dir
|
||||||
|
|
||||||
|
if ! bashio::fs.directory_exists '/share/transmission'; then
|
||||||
|
mkdir '/share/transmission'
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! bashio::fs.file_exists '/share/transmission/settings.json'; then
|
||||||
|
echo "{}" > /share/transmission/settings.json
|
||||||
|
fi
|
||||||
|
|
||||||
|
CONFIG=$(</share/transmission/settings.json)
|
||||||
|
|
||||||
|
download_dir=$(bashio::config 'download_dir')
|
||||||
|
incomplete_dir=$(bashio::config 'incomplete_dir')
|
||||||
|
|
||||||
|
# Defaults
|
||||||
|
CONFIG=$(bashio::jq "${CONFIG}" ".\"incomplete-dir\"=\"${incomplete_dir}\"")
|
||||||
|
CONFIG=$(bashio::jq "${CONFIG}" ".\"download-dir\"=\"${download_dir}\"")
|
||||||
|
CONFIG=$(bashio::jq "${CONFIG}" ".\"incomplete-dir-enabled\"=true")
|
||||||
|
CONFIG=$(bashio::jq "${CONFIG}" ".\"rpc-whitelist-enabled\"=false")
|
||||||
|
CONFIG=$(bashio::jq "${CONFIG}" ".\"rpc-host-whitelist-enabled\"=false")
|
||||||
|
CONFIG=$(bashio::jq "${CONFIG}" ".\"bind-address-ipv4\"=\"0.0.0.0\"")
|
||||||
|
|
||||||
|
echo "${CONFIG}" > /share/transmission/settings.json
|
||||||
21
joal/rootfs/etc/cont-init.d/50-mounts.sh
Normal file
21
joal/rootfs/etc/cont-init.d/50-mounts.sh
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
#!/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/$disk && \
|
||||||
|
if [ ! -d /share/$disk ]; then
|
||||||
|
echo "Creating /share/$disk"
|
||||||
|
mkdir -p /share/$disk
|
||||||
|
chown -R abc:abc /share/$disk
|
||||||
|
fi
|
||||||
|
mount /dev/$disk /share/$disk && \
|
||||||
|
bashio::log.info "Success!"
|
||||||
|
done || \
|
||||||
|
bashio::log.warning "Protection mode is ON. Unable to mount local drives!"
|
||||||
|
fi
|
||||||
Reference in New Issue
Block a user