Fixed rclone
This commit is contained in:
parent
f378cf58e7
commit
9ee1459669
16 changed files with 184 additions and 52 deletions
|
@ -19,10 +19,10 @@
|
||||||
#
|
#
|
||||||
# | Mount Location | Description |
|
# | Mount Location | Description |
|
||||||
# |-----------------------|-----------------------------------------------------------------------------------------------------------------------|
|
# |-----------------------|-----------------------------------------------------------------------------------------------------------------------|
|
||||||
# | `/mnt/s3-private` | Private system-wide bucket used for any private files that should not be able to be accessed publicly over HTTPS |
|
# | `/mnt/Private` | Private system-wide bucket used for any private files that should not be able to be accessed publicly over HTTPS |
|
||||||
# | `/mnt/s3-public` | Public system-wide bucket that can be accessed by anyone over HTTPS with the bucket's URL (provided by CloudFlare R2) |
|
# | `/mnt/Public` | Public system-wide bucket that can be accessed by anyone over HTTPS with the bucket's URL (provided by CloudFlare R2) |
|
||||||
# | `/mnt/s3-docker` | Private system-wide bucket used for storing Docker-related backups / files |
|
# | N/A | Private system-wide bucket used for storing Docker-related backups / files |
|
||||||
# | `/mnt/s3-system` | Private system-wide bucket similar to `/mnt/s3-private` but intended for system file backups |
|
# | N/A | Private system-wide bucket similar to `/mnt/Private` but intended for system file backups |
|
||||||
# | `$HOME/.local/mnt/s3` | Private user-specific bucket (used for backing up application settings) |
|
# | `$HOME/.local/mnt/s3` | Private user-specific bucket (used for backing up application settings) |
|
||||||
#
|
#
|
||||||
# ## Permissions
|
# ## Permissions
|
||||||
|
@ -52,7 +52,7 @@
|
||||||
if command -v rclone > /dev/null; then
|
if command -v rclone > /dev/null; then
|
||||||
logg info 'Ensuring /var/cache/rclone exists'
|
logg info 'Ensuring /var/cache/rclone exists'
|
||||||
sudo mkdir -p /var/cache/rclone
|
sudo mkdir -p /var/cache/rclone
|
||||||
sudo chmod 700 /var/cache/rclone
|
sudo chmod 770 /var/cache/rclone
|
||||||
# Add user / group with script in ~/.local/bin/add-user, if it is available
|
# Add user / group with script in ~/.local/bin/add-user, if it is available
|
||||||
if command -v add-user > /dev/null; then
|
if command -v add-user > /dev/null; then
|
||||||
sudo add-user rclone
|
sudo add-user rclone
|
||||||
|
@ -61,7 +61,7 @@ if command -v rclone > /dev/null; then
|
||||||
|
|
||||||
logg info 'Ensuring /var/log/rclone exists'
|
logg info 'Ensuring /var/log/rclone exists'
|
||||||
sudo mkdir -p /var/log/rclone
|
sudo mkdir -p /var/log/rclone
|
||||||
sudo chmod 700 /var/log/rclone
|
sudo chmod 770 /var/log/rclone
|
||||||
sudo chown -Rf rclone:rclone /var/log/rclone
|
sudo chown -Rf rclone:rclone /var/log/rclone
|
||||||
|
|
||||||
logg info 'Adding ~/.local/bin/rclone-mount to /usr/local/bin'
|
logg info 'Adding ~/.local/bin/rclone-mount to /usr/local/bin'
|
||||||
|
@ -70,10 +70,11 @@ if command -v rclone > /dev/null; then
|
||||||
|
|
||||||
logg info 'Adding ~/.config/rclone/rcloneignore to /etc/rcloneignore'
|
logg info 'Adding ~/.config/rclone/rcloneignore to /etc/rcloneignore'
|
||||||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/rclone/rcloneignore" /etc/rcloneignore
|
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/rclone/rcloneignore" /etc/rcloneignore
|
||||||
sudo chmod 644 /etc/rcloneignore
|
sudo chmod 640 /etc/rcloneignore
|
||||||
|
|
||||||
logg info 'Adding ~/.config/rclone/system-rclone.conf to /etc/rclone.conf'
|
logg info 'Adding ~/.config/rclone/system-rclone.conf to /etc/rclone.conf'
|
||||||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/rclone/system-rclone.conf" /etc/rclone.conf
|
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/rclone/system-rclone.conf" /etc/rclone.conf
|
||||||
|
sudo chmod 640 /etc/rclone.conf
|
||||||
|
|
||||||
### Add / configure service files
|
### Add / configure service files
|
||||||
if [ -d /etc/systemd/system ]; then
|
if [ -d /etc/systemd/system ]; then
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
#
|
#
|
||||||
# If CloudFlare R2 credentials are provided, Samba is configured to store its shared files in the Rclone mounts so that your
|
# If CloudFlare R2 credentials are provided, Samba is configured to store its shared files in the Rclone mounts so that your
|
||||||
# Samba shares are synchronized to the S3 buckets. If not, new folders are created. Either way, the folder / symlink that the
|
# Samba shares are synchronized to the S3 buckets. If not, new folders are created. Either way, the folder / symlink that the
|
||||||
# shares host data from are stored at `/mnt/share-private` and `/mnt/share-public` (*Note: Different paths are used on macOS*).
|
# shares host data from are stored at `/mnt/Private` and `/mnt/Public` (*Note: Different paths are used on macOS*).
|
||||||
#
|
#
|
||||||
# 1. The **public** share (named "Public") can be accessed by anyone (including write permissions with the default settings)
|
# 1. The **public** share (named "Public") can be accessed by anyone (including write permissions with the default settings)
|
||||||
# 2. The **private** share (named "Private") can be accessed by specifying the PAM credentials of anyone who has an account that is included in the `sambausers` group
|
# 2. The **private** share (named "Private") can be accessed by specifying the PAM credentials of anyone who has an account that is included in the `sambausers` group
|
||||||
|
@ -54,6 +54,11 @@
|
||||||
|
|
||||||
### Configure Samba server
|
### Configure Samba server
|
||||||
if command -v smbd > /dev/null; then
|
if command -v smbd > /dev/null; then
|
||||||
|
# Add user / group with script in ~/.local/bin/add-user, if it is available
|
||||||
|
if command -v add-user > /dev/null; then
|
||||||
|
sudo add-user rclone
|
||||||
|
fi
|
||||||
|
|
||||||
### Define share locations
|
### Define share locations
|
||||||
if [ -d /Applications ] && [ -d /System ]; then
|
if [ -d /Applications ] && [ -d /System ]; then
|
||||||
### macOS does not have `/mnt` folder so use `/Volumes` location
|
### macOS does not have `/mnt` folder so use `/Volumes` location
|
||||||
|
@ -61,29 +66,49 @@ if command -v smbd > /dev/null; then
|
||||||
else
|
else
|
||||||
MNT_FOLDER='mnt'
|
MNT_FOLDER='mnt'
|
||||||
fi
|
fi
|
||||||
PRIVATE_CLOUD="/$MNT_FOLDER/Cloud (Private)"
|
PRIVATE_SHARE="/$MNT_FOLDER/Private"
|
||||||
PUBLIC_CLOUD="/$MNT_FOLDER/Cloud (Public)"
|
PUBLIC_SHARE="/$MNT_FOLDER/Public"
|
||||||
PRIVATE_SHARE="/$MNT_FOLDER/Network Share (Private)"
|
|
||||||
PUBLIC_SHARE="/$MNT_FOLDER/Network Share (Public)"
|
|
||||||
|
|
||||||
### Ensure private Samba directory / symlink exists
|
|
||||||
if [ -d "$PRIVATE_CLOUD" ] && [ ! -d "$PRIVATE_SHARE" ]; then
|
|
||||||
sudo ln -s "$PRIVATE_CLOUD" "$PRIVATE_SHARE"
|
|
||||||
else
|
|
||||||
sudo mkdir -p "$PRIVATE_SHARE"
|
|
||||||
fi
|
|
||||||
|
|
||||||
### Ensure public Samba directory / symlink exists
|
|
||||||
if [ -d "$PUBLIC_CLOUD" ] && [ ! -d "$PUBLIC_SHARE" ]; then
|
|
||||||
sudo ln -s "$PUBLIC_CLOUD" "$PUBLIC_SHARE"
|
|
||||||
else
|
|
||||||
sudo mkdir -p "$PUBLIC_SHARE"
|
|
||||||
fi
|
|
||||||
|
|
||||||
### Copy the Samba server configuration file
|
### Copy the Samba server configuration file
|
||||||
if [ -d /Applications ] && [ -d /System ]; then
|
if [ -d /Applications ] && [ -d /System ]; then
|
||||||
logg warn 'TODO Add logic that applies the Samba configuration for macOS'
|
logg info 'Ensuring /Volumes for S3 buckets and Samba shares are configured'
|
||||||
|
|
||||||
|
logg info "Ensuring $PRIVATE_SHARE is created"
|
||||||
|
sudo mkdir -p "$PRIVATE_SHARE"
|
||||||
|
sudo chmod 770 "$PRIVATE_SHARE"
|
||||||
|
sudo chown -Rf rclone:rclone "$PRIVATE_SHARE"
|
||||||
|
|
||||||
|
logg info "Ensuring $PUBLIC_SHARE is created"
|
||||||
|
sudo mkdir -p "$PUBLIC_SHARE"
|
||||||
|
sudo chmod 775 "$PUBLIC_SHARE"
|
||||||
|
sudo chown -Rf rclone:rclone "$PUBLIC_SHARE"
|
||||||
|
|
||||||
|
logg info "Ensuring $HOME/Public is created"
|
||||||
|
mkdir -p "$HOME/Public"
|
||||||
|
chmod 775 "$HOME/Public"
|
||||||
|
chown -Rf {{ .user.username }}:rclone "$HOME/Public"
|
||||||
|
|
||||||
|
sudo sharing -a "$PRIVATE_SHARE" -S "Private (System)" -n "Private (System)" -g 000 -s 001 -E 1 -R 1 && logg success "Configured $PRIVATE_SHARE as a private Samba share"
|
||||||
|
sudo sharing -a "$PUBLIC_SHARE" -S "Public (System)" -n "Public (System)" -g 001 -s 001 -E 1 -R 0 && logg success "Configured $PUBLIC_SHARE as a public Samba share"
|
||||||
|
sudo sharing -a "$HOME/Public" -S "Public (User)" -n "Public (User)" -g 001 -s 001 -E 1 -R 0 && logg success "Configured $HOME/Public as a public Samba share"
|
||||||
else
|
else
|
||||||
|
logg info 'Ensuring /mnt for S3 buckets and Samba shares are configured'
|
||||||
|
|
||||||
|
logg info "Ensuring $PRIVATE_SHARE is created"
|
||||||
|
sudo mkdir -p "$PRIVATE_SHARE"
|
||||||
|
sudo chmod 770 "$PRIVATE_SHARE"
|
||||||
|
sudo chown -Rf rclone:rclone "$PRIVATE_SHARE"
|
||||||
|
|
||||||
|
logg info "Ensuring $PUBLIC_SHARE is created"
|
||||||
|
sudo mkdir -p "$PUBLIC_SHARE"
|
||||||
|
sudo chmod 775 "$PUBLIC_SHARE"
|
||||||
|
sudo chown -Rf rclone:rclone "$PUBLIC_SHARE"
|
||||||
|
|
||||||
|
logg info "Ensuring $HOME/Public is created"
|
||||||
|
mkdir -p "$HOME/Public"
|
||||||
|
chmod 775 "$HOME/Public"
|
||||||
|
chown -Rf {{ .user.username }}:rclone "$HOME/Public"
|
||||||
|
|
||||||
logg info "Copying Samba server configuration to /etc/samba/smb.conf"
|
logg info "Copying Samba server configuration to /etc/samba/smb.conf"
|
||||||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/samba/config" "/etc/samba/smb.conf"
|
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/samba/config" "/etc/samba/smb.conf"
|
||||||
|
|
||||||
|
|
|
@ -1,3 +1,3 @@
|
||||||
{{- if and (or (and (stat (joinPath .host.home ".config" "age" "chezmoi.txt")) (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_ID"))) (env "CLOUDFLARE_R2_ID")) (or (and (stat (joinPath .host.home ".config" "age" "chezmoi.txt")) (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_SECRET"))) (env "CLOUDFLARE_R2_SECRET")) (ne .user.cloudflare.r2 "") -}}
|
{{- if and (or (and (stat (joinPath .host.home ".config" "age" "chezmoi.txt")) (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_ID"))) (env "CLOUDFLARE_R2_ID")) (or (and (stat (joinPath .host.home ".config" "age" "chezmoi.txt")) (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_SECRET"))) (env "CLOUDFLARE_R2_SECRET")) (ne .user.cloudflare.r2 "") -}}
|
||||||
/mnt/s3-private
|
/{{- if eq .host.distro.id "darwin" -}}Volumes{{- else -}}mnt{{- end -}}/Private
|
||||||
{{- end -}}
|
{{- end -}}
|
|
@ -1,3 +1,3 @@
|
||||||
{{- if and (or (and (stat (joinPath .host.home ".config" "age" "chezmoi.txt")) (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_ID"))) (env "CLOUDFLARE_R2_ID")) (or (and (stat (joinPath .host.home ".config" "age" "chezmoi.txt")) (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_SECRET"))) (env "CLOUDFLARE_R2_SECRET")) (ne .user.cloudflare.r2 "") -}}
|
{{- if and (or (and (stat (joinPath .host.home ".config" "age" "chezmoi.txt")) (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_ID"))) (env "CLOUDFLARE_R2_ID")) (or (and (stat (joinPath .host.home ".config" "age" "chezmoi.txt")) (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_SECRET"))) (env "CLOUDFLARE_R2_SECRET")) (ne .user.cloudflare.r2 "") -}}
|
||||||
/mnt/s3-public
|
/{{- if eq .host.distro.id "darwin" -}}Volumes{{- else -}}mnt{{- end -}}/Public
|
||||||
{{- end -}}
|
{{- end -}}
|
23
home/Library/LaunchDaemons/rclone.private.plist
Normal file
23
home/Library/LaunchDaemons/rclone.private.plist
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
||||||
|
<plist version="1.0">
|
||||||
|
<dict>
|
||||||
|
<key>KeepAlive</key>
|
||||||
|
<true/>
|
||||||
|
<key>Label</key>
|
||||||
|
<string>rclone.private</string>
|
||||||
|
<key>ProgramArguments</key>
|
||||||
|
<array>
|
||||||
|
<string>/usr/local/bin/rclone-mount</string>
|
||||||
|
<string>rclone</string>
|
||||||
|
<string>rclone</string>
|
||||||
|
<string>Private</string>
|
||||||
|
</array>
|
||||||
|
<key>RunAtLoad</key>
|
||||||
|
<true/>
|
||||||
|
<key>StandardErrorPath</key>
|
||||||
|
<string>/var/log/rclone/private-daemon.error.log</string>
|
||||||
|
<key>StandardOutPath</key>
|
||||||
|
<string>/var/log/rclone/private-daemon.debug.log</string>
|
||||||
|
</dict>
|
||||||
|
</plist>
|
23
home/Library/LaunchDaemons/rclone.public.plist
Normal file
23
home/Library/LaunchDaemons/rclone.public.plist
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
||||||
|
<plist version="1.0">
|
||||||
|
<dict>
|
||||||
|
<key>KeepAlive</key>
|
||||||
|
<true/>
|
||||||
|
<key>Label</key>
|
||||||
|
<string>rclone.public</string>
|
||||||
|
<key>ProgramArguments</key>
|
||||||
|
<array>
|
||||||
|
<string>/usr/local/bin/rclone-mount</string>
|
||||||
|
<string>rclone</string>
|
||||||
|
<string>rclone</string>
|
||||||
|
<string>Public</string>
|
||||||
|
</array>
|
||||||
|
<key>RunAtLoad</key>
|
||||||
|
<true/>
|
||||||
|
<key>StandardErrorPath</key>
|
||||||
|
<string>/var/log/rclone/public-daemon.error.log</string>
|
||||||
|
<key>StandardOutPath</key>
|
||||||
|
<string>/var/log/rclone/public-daemon.debug.log</string>
|
||||||
|
</dict>
|
||||||
|
</plist>
|
23
home/Library/LaunchDaemons/rclone.user.plist.tmpl
Normal file
23
home/Library/LaunchDaemons/rclone.user.plist.tmpl
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
||||||
|
<plist version="1.0">
|
||||||
|
<dict>
|
||||||
|
<key>KeepAlive</key>
|
||||||
|
<true/>
|
||||||
|
<key>Label</key>
|
||||||
|
<string>rclone.public</string>
|
||||||
|
<key>ProgramArguments</key>
|
||||||
|
<array>
|
||||||
|
<string>/usr/local/bin/rclone-mount</string>
|
||||||
|
<string>user</string>
|
||||||
|
<string>{{ .user.username }}</string>
|
||||||
|
<string>s3</string>
|
||||||
|
</array>
|
||||||
|
<key>RunAtLoad</key>
|
||||||
|
<true/>
|
||||||
|
<key>StandardErrorPath</key>
|
||||||
|
<string>/Users/{{ .user.username }}/.local/share/rclone/error.log</string>
|
||||||
|
<key>StandardOutPath</key>
|
||||||
|
<string>/Users/{{ .user.username }}/.local/share/rclone/debug.log</string>
|
||||||
|
</dict>
|
||||||
|
</plist>
|
|
@ -14,4 +14,19 @@ if [ -d /Applications ] && [ -d /System ]; then
|
||||||
sudo cp -f "$HOME/Library/LaunchDaemons/com.cloudflare.warp.plist" '/Library/LaunchDaemons/com.cloudflare.warp.plist'
|
sudo cp -f "$HOME/Library/LaunchDaemons/com.cloudflare.warp.plist" '/Library/LaunchDaemons/com.cloudflare.warp.plist'
|
||||||
sudo launchctl load "/Library/LaunchDaemons/com.cloudflare.warp.plist"
|
sudo launchctl load "/Library/LaunchDaemons/com.cloudflare.warp.plist"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
### Enable Rclone mounts
|
||||||
|
if [ -f "$HOME/Library/LaunchDaemons/rclone.private.plist" ] && [ ! -f "/Library/LaunchDaemons/rclone.private.plist" ]; then
|
||||||
|
sudo mkdir -p /Library/LaunchDaemons
|
||||||
|
sudo cp -f "$HOME/Library/LaunchDaemons/rclone.private.plist" '/Library/LaunchDaemons/rclone.private.plist'
|
||||||
|
sudo launchctl load '/Library/LaunchDaemons/rclone.private.plist'
|
||||||
|
fi
|
||||||
|
if [ -f "$HOME/Library/LaunchDaemons/rclone.public.plist" ] && [ ! -f "/Library/LaunchDaemons/rclone.public.plist" ]; then
|
||||||
|
sudo mkdir -p /Library/LaunchDaemons
|
||||||
|
sudo cp -f "$HOME/Library/LaunchDaemons/rclone.public.plist" '/Library/LaunchDaemons/rclone.public.plist'
|
||||||
|
sudo launchctl load '/Library/LaunchDaemons/rclone.public.plist'
|
||||||
|
fi
|
||||||
|
if [ -f "$HOME/Library/LaunchDaemons/rclone.user.plist" ]; then
|
||||||
|
launchctl load "$HOME/Library/LaunchDaemons/rclone.user.plist"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
|
@ -18,7 +18,7 @@ tee -a "$CONFIG_FILE" > /dev/null <<EOT
|
||||||
[{{ .user.username}}-s3]
|
[{{ .user.username}}-s3]
|
||||||
access_key_id = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_ID")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_ID" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_ID" -}}{{ end }}
|
access_key_id = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_ID")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_ID" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_ID" -}}{{ end }}
|
||||||
acl = private
|
acl = private
|
||||||
endpoint = {{ .user.cloudflare.r2 }}.r2.cloudflarestorage.com/user
|
endpoint = {{ .user.cloudflare.r2 }}.r2.cloudflarestorage.com
|
||||||
provider = Cloudflare
|
provider = Cloudflare
|
||||||
region = auto
|
region = auto
|
||||||
secret_access_key = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_SECRET")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_SECRET" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_SECRET" -}}{{ end }}
|
secret_access_key = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_SECRET")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_SECRET" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_SECRET" -}}{{ end }}
|
||||||
|
|
|
@ -2,25 +2,25 @@
|
||||||
[docker]
|
[docker]
|
||||||
access_key_id = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_ID")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_ID" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_ID" -}}{{ end }}
|
access_key_id = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_ID")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_ID" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_ID" -}}{{ end }}
|
||||||
acl = private
|
acl = private
|
||||||
endpoint = {{ .user.cloudflare.r2 }}.r2.cloudflarestorage.com/docker
|
endpoint = {{ .user.cloudflare.r2 }}.r2.cloudflarestorage.com
|
||||||
env_auth = false
|
env_auth = false
|
||||||
provider = Cloudflare
|
provider = Cloudflare
|
||||||
secret_access_key = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_SECRET")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_SECRET" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_SECRET" -}}{{ end }}
|
secret_access_key = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_SECRET")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_SECRET" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_SECRET" -}}{{ end }}
|
||||||
type = s3
|
type = s3
|
||||||
|
|
||||||
[private]
|
[Private]
|
||||||
access_key_id = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_ID")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_ID" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_ID" -}}{{ end }}
|
access_key_id = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_ID")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_ID" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_ID" -}}{{ end }}
|
||||||
acl = private
|
acl = private
|
||||||
endpoint = {{ .user.cloudflare.r2 }}.r2.cloudflarestorage.com/private
|
endpoint = {{ .user.cloudflare.r2 }}.r2.cloudflarestorage.com
|
||||||
env_auth = false
|
env_auth = false
|
||||||
provider = Cloudflare
|
provider = Cloudflare
|
||||||
secret_access_key = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_SECRET")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_SECRET" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_SECRET" -}}{{ end }}
|
secret_access_key = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_SECRET")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_SECRET" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_SECRET" -}}{{ end }}
|
||||||
type = s3
|
type = s3
|
||||||
|
|
||||||
[public]
|
[Public]
|
||||||
access_key_id = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_ID")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_ID" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_ID" -}}{{ end }}
|
access_key_id = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_ID")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_ID" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_ID" -}}{{ end }}
|
||||||
acl = public-read
|
acl = public-read
|
||||||
endpoint = {{ .user.cloudflare.r2 }}.r2.cloudflarestorage.com/public
|
endpoint = {{ .user.cloudflare.r2 }}.r2.cloudflarestorage.com
|
||||||
env_auth = false
|
env_auth = false
|
||||||
provider = Cloudflare
|
provider = Cloudflare
|
||||||
secret_access_key = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_SECRET")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_SECRET" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_SECRET" -}}{{ end }}
|
secret_access_key = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_SECRET")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_SECRET" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_SECRET" -}}{{ end }}
|
||||||
|
@ -29,7 +29,7 @@ type = s3
|
||||||
[system]
|
[system]
|
||||||
access_key_id = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_ID")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_ID" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_ID" -}}{{ end }}
|
access_key_id = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_ID")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_ID" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_ID" -}}{{ end }}
|
||||||
acl = private
|
acl = private
|
||||||
endpoint = {{ .user.cloudflare.r2 }}.r2.cloudflarestorage.com/system
|
endpoint = {{ .user.cloudflare.r2 }}.r2.cloudflarestorage.com
|
||||||
env_auth = false
|
env_auth = false
|
||||||
provider = Cloudflare
|
provider = Cloudflare
|
||||||
secret_access_key = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_SECRET")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_SECRET" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_SECRET" -}}{{ end }}
|
secret_access_key = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_SECRET")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_SECRET" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_SECRET" -}}{{ end }}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
**/.**
|
.*
|
||||||
**/_**
|
_*
|
||||||
**/*.db
|
*.box
|
||||||
**/*.box
|
*.db
|
||||||
**/Network Trash Folder**
|
node_modules/**
|
||||||
**/node_modules**
|
Network Trash Folder/**
|
|
@ -5,8 +5,8 @@ After=network-online.target
|
||||||
[Service]
|
[Service]
|
||||||
Type=simple
|
Type=simple
|
||||||
User=rclone
|
User=rclone
|
||||||
ExecStart=/usr/local/bin/rclone-mount "rclone" "rclone" "Cloud (Private)"
|
ExecStart=/usr/local/bin/rclone-mount "rclone" "rclone" "Private"
|
||||||
ExecStop=/bin/fusermount -u "/mnt/Cloud (Private)"
|
ExecStop=/bin/fusermount -u "/mnt/Private"
|
||||||
Restart=always
|
Restart=always
|
||||||
RestartSec=10
|
RestartSec=10
|
||||||
|
|
||||||
|
|
|
@ -5,8 +5,8 @@ After=network-online.target
|
||||||
[Service]
|
[Service]
|
||||||
Type=simple
|
Type=simple
|
||||||
User=rclone
|
User=rclone
|
||||||
ExecStart=/usr/local/bin/rclone-mount "rclone" "rclone" "Cloud (Public)"
|
ExecStart=/usr/local/bin/rclone-mount "rclone" "rclone" "Public"
|
||||||
ExecStop=/bin/fusermount -u "/mnt/Cloud (Public)"
|
ExecStop=/bin/fusermount -u "/mnt/Public"
|
||||||
Restart=always
|
Restart=always
|
||||||
RestartSec=10
|
RestartSec=10
|
||||||
|
|
||||||
|
|
|
@ -28,7 +28,7 @@
|
||||||
comment = Authenticated share with read/write capabilities (backed up to S3)
|
comment = Authenticated share with read/write capabilities (backed up to S3)
|
||||||
follow symlinks = yes
|
follow symlinks = yes
|
||||||
guest only = no
|
guest only = no
|
||||||
path = /mnt/Network Share (Private)
|
path = /mnt/Private
|
||||||
public = no
|
public = no
|
||||||
unix extension = yes
|
unix extension = yes
|
||||||
valid users = @sambausers
|
valid users = @sambausers
|
||||||
|
@ -40,7 +40,16 @@
|
||||||
comment = Public folder provided for file sharing on the LAN (backed up to S3)
|
comment = Public folder provided for file sharing on the LAN (backed up to S3)
|
||||||
follow symlinks = no
|
follow symlinks = no
|
||||||
guest only = yes
|
guest only = yes
|
||||||
path = /mnt/Network Share (Public)
|
path = /mnt/Public
|
||||||
|
public = yes
|
||||||
|
writable = yes
|
||||||
|
|
||||||
|
[User]
|
||||||
|
browsable = yes
|
||||||
|
comment = Public user home directory folder for file sharing on the LAN
|
||||||
|
follow symlinks = no
|
||||||
|
guest only = yes
|
||||||
|
path = /home/{{ .user.name }}/Public
|
||||||
public = yes
|
public = yes
|
||||||
writable = yes
|
writable = yes
|
||||||
|
|
||||||
|
|
|
@ -33,7 +33,9 @@ fi
|
||||||
### Ensure folders exist
|
### Ensure folders exist
|
||||||
for FOLDER in "$CACHE_FOLDER" "$CONFIG_FOLDER" "$LOG_FOLDER" "$MOUNT_PATH"; do
|
for FOLDER in "$CACHE_FOLDER" "$CONFIG_FOLDER" "$LOG_FOLDER" "$MOUNT_PATH"; do
|
||||||
if [ ! -d "$FOLDER" ]; then
|
if [ ! -d "$FOLDER" ]; then
|
||||||
mkdir -p "$FOLDER" || echo "ERROR: Need permissions for $FOLDER"
|
sudo mkdir -p "$FOLDER" || echo "ERROR: Need permissions for $FOLDER"
|
||||||
|
sudo chmod 755 "$FOLDER"
|
||||||
|
sudo chown -Rf rclone:rclone "$FOLDER"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
|
@ -44,7 +46,10 @@ if [ ! -f "$RCLONE_IGNORE" ] && [ -f "/etc/rcloneignore" ]; then
|
||||||
fi
|
fi
|
||||||
|
|
||||||
### Mount
|
### Mount
|
||||||
/usr/bin/rclone --config="$CONFIG_FOLDER/rclone.conf" \
|
MOUNT_LOWERCASE="$(echo "$MOUNT" | tr "[:upper:]" "[:lower:]")"
|
||||||
|
unset AWS_CA_BUNDLE
|
||||||
|
export PATH="$PATH:/usr/local/bin:/usr/bin"
|
||||||
|
sudo rclone --config="$CONFIG_FOLDER/rclone.conf" \
|
||||||
mount \
|
mount \
|
||||||
--cache-tmp-upload-path="$CACHE_FOLDER/$MOUNT-upload" \
|
--cache-tmp-upload-path="$CACHE_FOLDER/$MOUNT-upload" \
|
||||||
--cache-chunk-path="$CACHE_FOLDER/$MOUNT-chunks" \
|
--cache-chunk-path="$CACHE_FOLDER/$MOUNT-chunks" \
|
||||||
|
@ -52,6 +57,8 @@ fi
|
||||||
--cache-writes \
|
--cache-writes \
|
||||||
--cache-dir="$CACHE_FOLDER/$MOUNT-vfs" \
|
--cache-dir="$CACHE_FOLDER/$MOUNT-vfs" \
|
||||||
--cache-db-path="$CACHE_FOLDER/$MOUNT-db" \
|
--cache-db-path="$CACHE_FOLDER/$MOUNT-db" \
|
||||||
|
--daemon \
|
||||||
|
--noapplexattr \
|
||||||
--log-file="$LOG_FILE" \
|
--log-file="$LOG_FILE" \
|
||||||
--no-modtime \
|
--no-modtime \
|
||||||
--drive-use-trash \
|
--drive-use-trash \
|
||||||
|
@ -60,6 +67,7 @@ fi
|
||||||
--bwlimit=40M \
|
--bwlimit=40M \
|
||||||
--dir-cache-time=60m \
|
--dir-cache-time=60m \
|
||||||
--vfs-cache-mode full \
|
--vfs-cache-mode full \
|
||||||
|
--volname "$MOUNT" \
|
||||||
--cache-info-age=60m \
|
--cache-info-age=60m \
|
||||||
--filter-from="$RCLONE_IGNORE"
|
--filter-from="$RCLONE_IGNORE" \
|
||||||
"$MOUNT":/ "$MOUNT_PATH"
|
"$MOUNT_LOWERCASE":"$MOUNT_LOWERCASE" "$MOUNT_PATH"
|
||||||
|
|
|
@ -2154,6 +2154,7 @@ softwarePackages:
|
||||||
_github: https://github.com/imp/dnsmasq
|
_github: https://github.com/imp/dnsmasq
|
||||||
_home: null
|
_home: null
|
||||||
_name: dnsmasq
|
_name: dnsmasq
|
||||||
|
_service: dnsmasq
|
||||||
ansible: professormanhattan.dnsmasq
|
ansible: professormanhattan.dnsmasq
|
||||||
apt: dnsmasq
|
apt: dnsmasq
|
||||||
brew: dnsmasq
|
brew: dnsmasq
|
||||||
|
@ -6101,6 +6102,7 @@ softwarePackages:
|
||||||
_github: null
|
_github: null
|
||||||
_home: https://www.nomadproject.io/
|
_home: https://www.nomadproject.io/
|
||||||
_name: HashiCorp Nomad
|
_name: HashiCorp Nomad
|
||||||
|
_service: nomad
|
||||||
ansible: professormanhattan.nomad
|
ansible: professormanhattan.nomad
|
||||||
brew: nomad
|
brew: nomad
|
||||||
choco: nomad
|
choco: nomad
|
||||||
|
@ -8238,6 +8240,7 @@ softwarePackages:
|
||||||
_github: null
|
_github: null
|
||||||
_home: null
|
_home: null
|
||||||
_name: Stubby
|
_name: Stubby
|
||||||
|
_service: stubby
|
||||||
_post:brew:darwin: bash "$(brew --prefix stubby)/sbin/stubby-setdns-macos.sh" && brew services start stubby
|
_post:brew:darwin: bash "$(brew --prefix stubby)/sbin/stubby-setdns-macos.sh" && brew services start stubby
|
||||||
brew:darwin: stubby
|
brew:darwin: stubby
|
||||||
surge:
|
surge:
|
||||||
|
@ -8861,6 +8864,7 @@ softwarePackages:
|
||||||
- privoxy
|
- privoxy
|
||||||
_home: https://www.privoxy.org/
|
_home: https://www.privoxy.org/
|
||||||
_name: Privoxy
|
_name: Privoxy
|
||||||
|
_service: privoxy
|
||||||
apt: privoxy
|
apt: privoxy
|
||||||
brew: privoxy
|
brew: privoxy
|
||||||
dnf: privoxy
|
dnf: privoxy
|
||||||
|
@ -8873,6 +8877,7 @@ softwarePackages:
|
||||||
_github: https://github.com/TheTorProject
|
_github: https://github.com/TheTorProject
|
||||||
_home: https://www.torproject.org/
|
_home: https://www.torproject.org/
|
||||||
_name: TOR
|
_name: TOR
|
||||||
|
_service: tor
|
||||||
ansible:linux: professormanhattan.tor
|
ansible:linux: professormanhattan.tor
|
||||||
apt: tor
|
apt: tor
|
||||||
brew: tor
|
brew: tor
|
||||||
|
|
Loading…
Reference in a new issue