decluttarr

This commit is contained in:
Tomás Limpinho
2025-11-13 17:34:15 +00:00
parent b053fc8019
commit c51a7d81be
7 changed files with 200 additions and 1 deletions

View File

@ -28,3 +28,4 @@
- jellyfin
- flaresolverr
- jellyseerr
- decluttarr

View File

@ -0,0 +1,90 @@
apiVersion: apps/v1
kind: Deployment
metadata:
name: decluttarr
namespace: stack-arr
spec:
replicas: 1
selector:
matchLabels:
app: decluttarr
template:
metadata:
labels:
app: decluttarr
spec:
imagePullSecrets:
- name: regcred
containers:
- name: decluttarr
image: ghcr.io/manimatter/decluttarr:latest
env:
- name: PUID
value: "1013"
- name: PGID
value: "1013"
- name: TZ
value: 'Etc/UTC'
- name: REMOVE_TIMER
value: '1'
- name: REMOVE_FAILED
value: 'True'
- name: REMOVE_FAILED_IMPORTS
value: 'True'
- name: REMOVE_METADATA_MISSING
value: 'True'
- name: REMOVE_MISSING_FILES
value: 'True'
- name: REMOVE_ORPHANS
value: 'True'
- name: REMOVE_SLOW
value: 'False'
- name: REMOVE_STALLED
value: 'True'
- name: REMOVE_UNMONITORED
value: 'False'
- name: MIN_DOWNLOAD_SPEED
value: '100'
- name: PERMITTED_ATTEMPTS
value: '2'
- name: RADARR_URL
value: http://192.168.1.243:7878/radarr
- name: RADARR_KEY
valueFrom:
secretKeyRef:
name: decluttarr-secret
key: radarrapikey
- name: SONARR_URL
value: http://sonarr-service.stack-arr.svc.cluster.local:8989
- name: SONARR_KEY
valueFrom:
secretKeyRef:
name: decluttarr-secret
key: sonarrapikey
- name: QBITTORRENT_URL
value: http://qbittorrent-service.stack-arr.svc.cluster.local:8080
- name: QBITTORRENT_USERNAME
valueFrom:
secretKeyRef:
name: decluttarr-secret
key: qbittorrentuser
- name: QBITTORRENT_PASSWORD
valueFrom:
secretKeyRef:
name: decluttarr-secret
key: qbittorrentpass
volumeMounts:
- name: config
mountPath: /config
- name: downloads
mountPath: /data/downloads
volumes:
- name: config
persistentVolumeClaim:
claimName: decluttarr-config-pvc
- name: downloads
persistentVolumeClaim:
claimName: qbittorrent-downloads-pvc

View File

@ -0,0 +1,12 @@
apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
name: decluttarr-nfs-csi
namespace: stack-arr
provisioner: nfs.csi.k8s.io
parameters:
server: 192.168.1.22
share: /mnt/fenix-main-nas-pool-0/data/k8s-Volumes/k8s-cluster-iac-deployed/stack-arr/decluttarr
allowVolumeExpansion: true
reclaimPolicy: Retain
---

View File

@ -0,0 +1,30 @@
apiVersion: v1
kind: PersistentVolume
metadata:
name: decluttarr-config-pv
namespace: stack-arr
spec:
capacity:
storage: 2Gi
storageClassName: decluttarr-nfs-csi
accessModes:
- ReadWriteOnce
persistentVolumeReclaimPolicy: Retain
nfs:
server: 192.168.1.22
path: /mnt/fenix-main-nas-pool-0/data/k8s-Volumes/k8s-cluster-iac-deployed/stack-arr/decluttarr/config
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: decluttarr-config-pvc
namespace: stack-arr
spec:
storageClassName: decluttarr-nfs-csi
accessModes:
- ReadWriteOnce
volumeName: decluttarr-config-pv
resources:
requests:
storage: 2Gi
---

View File

@ -0,0 +1,11 @@
apiVersion: v1
kind: Secret
metadata:
name: decluttarr-secret
namespace: stack-arr
type: Opaque
data:
qbittorrentuser: dXNlcm5hbWU=
qbittorrentpass: cGFzc3dvcmQ=
radarrapikey: YXBpa2V5
sonarrapikey: YXBpa2V5

View File

@ -0,0 +1,51 @@
- name: Remover o diretório /tmp/stack-arr/decluttarr/kubernetes-files
ansible.builtin.file:
path: /tmp/stack-arr/decluttarr/kubernetes-files
state: absent
- name: Criar diretório temporário no remoto
file:
path: /tmp/stack-arr/decluttarr/kubernetes-files
state: directory
mode: '0755'
- name: Copy file with owner and permissions
ansible.builtin.copy:
src: ../files
dest: /tmp/stack-arr/decluttarr/kubernetes-files
owner: fenix
group: root
mode: '0644'
- name: Obter várias notas do Bitwarden
shell: |
echo "unlock"
BW_SESSION=$(bw unlock {{ bw_password }} --raw)
echo "get item"
bw get item "{{ item.id }}" --session $BW_SESSION | jq -r '.notes' > {{ item.dest }}
loop:
- { id: "iac.ansible.stackarr.decluttarr.secret", dest: "/tmp/stack-arr/decluttarr/kubernetes-files/files/decluttarr-secret.yaml" }
args:
executable: /bin/bash
environment:
BW_PASSWORD: "{{ BW_PASSWORD }}"
- name: Listar conteúdo do diretório remoto
shell: ls -l /tmp/stack-arr/decluttarr/kubernetes-files/files
register: resultado_ls
- name: Mostrar resultado do ls
debug:
var: resultado_ls.stdout_lines
- name: Aplicar o stolon
become: yes
become_user: fenix
shell: |
kubectl apply -f /tmp/stack-arr/decluttarr/kubernetes-files/files/
environment:
KUBECONFIG: /home/fenix/.kube/config

View File

@ -0,0 +1,4 @@
bw_password: "{{ lookup('env', 'BW_PASSWORD') }}"
VAULTWARDEN_LINK: "{{ lookup('env', 'VAULTWARDEN_LINK') }}"
BW_CLIENTID: "{{ lookup('env', 'BW_CLIENTID') }}"
BW_CLIENTSECRET : "{{ lookup('env', 'BW_CLIENTSECRET') }}"