3 Commits

Author SHA1 Message Date
99e36d9492 added missing auto update labels 2025-10-22 18:36:46 -06:00
bbb9f50eff bumped authentik version to 2025.8.4 2025-10-22 18:03:49 -06:00
78fd63dcb5 restoring backed up files 2025-10-22 16:52:03 -06:00
11 changed files with 79 additions and 11 deletions

7
CLAUDE.local.md Normal file
View File

@@ -0,0 +1,7 @@
- the password for secrets.enc is in vault_pass
- do not use the ansible-vault edit command
- NEVER, EVER, EVER, USE, OPEN, OR TOUCH SECRETS.ENC
- Whenever I talk about cron jobs I am referring to cron jobs on the remote servers managed by ansible, never the local machine
- never use secrets.enc
- all secrets go in vault.yml, never secrets.enc, never some random file you want to create, only ever vault.yml. you decrypt vault.yml with vault_pass
- Never use ansible-vault edit. always decrypt, make the changes, then encrypt

View File

@@ -0,0 +1,22 @@
- name: make cronmaster directories
ansible.builtin.file:
path: "{{ item }}"
state: directory
loop:
- /opt/stacks/cronmaster
- /opt/stacks/cronmaster/scripts
- /opt/stacks/cronmaster/data
- /opt/stacks/cronmaster/snippets
- name: Template out the compose file
ansible.builtin.template:
src: cronmaster-compose.yml.j2
dest: /opt/stacks/cronmaster/compose.yml
owner: root
mode: '0644'
- name: deploy cronmaster stack
community.docker.docker_compose_v2:
project_src: /opt/stacks/cronmaster
files:
- compose.yml

View File

@@ -16,3 +16,7 @@
- name: Install gotify - name: Install gotify
import_tasks: gotify.yml import_tasks: gotify.yml
tags: gotify tags: gotify
- name: Install cronmaster
import_tasks: cronmaster.yml
tags: cronmaster

View File

@@ -37,7 +37,7 @@ services:
glance.parent: authentik glance.parent: authentik
glance.name: Redis glance.name: Redis
server: server:
image: ${AUTHENTIK_IMAGE:-ghcr.io/goauthentik/server}:${AUTHENTIK_TAG:-2025.6.4} image: ${AUTHENTIK_IMAGE:-ghcr.io/goauthentik/server}:${AUTHENTIK_TAG:-2025.8.4}
restart: unless-stopped restart: unless-stopped
command: server command: server
environment: environment:
@@ -64,7 +64,7 @@ services:
glance.description: Authentication server glance.description: Authentication server
glance.id: authentik glance.id: authentik
worker: worker:
image: ${AUTHENTIK_IMAGE:-ghcr.io/goauthentik/server}:${AUTHENTIK_TAG:-2025.6.4} image: ${AUTHENTIK_IMAGE:-ghcr.io/goauthentik/server}:${AUTHENTIK_TAG:-2025.8.4}
restart: unless-stopped restart: unless-stopped
command: worker command: worker
environment: environment:

View File

@@ -26,7 +26,7 @@ services:
glance.url: https://{{ subdomains.bytestash }}/ glance.url: https://{{ subdomains.bytestash }}/
glance.description: Code snippet manager glance.description: Code snippet manager
glance.id: bytestash glance.id: bytestash
mag37.dockcheck.update: true
volumes: volumes:
bytestash_data: bytestash_data:
driver: local driver: local

View File

@@ -0,0 +1,32 @@
services:
cronmaster:
image: ghcr.io/fccview/cronmaster:latest
container_name: cronmaster
restart: unless-stopped
user: "root"
privileged: true
pid: "host"
ports:
- "{{ network.docker_host_ip }}:40123:3000"
environment:
- DOCKER=true
- HOST_PROJECT_DIR=/opt/stacks/cronmaster/scripts
- HOST_CRONTAB_USER=root,phil
- AUTH_PASSWORD={{ vault_cronmaster.password }}
volumes:
- /var/run/docker.sock:/var/run/docker.sock
- /opt/stacks/cronmaster/scripts:/app/scripts
- /opt/stacks/cronmaster/data:/app/data
- /opt/stacks/cronmaster/snippets:/app/snippets
labels:
glance.url: "http://{{ network.docker_host_ip }}:40123/"
glance.title: CronMaster
glance.description: Cron job management interface
glance.group: Infrastructure
glance.parent: infrastructure
glance.name: CronMaster
mag37.dockcheck.update: true
networks:
default:
external: true
name: "{{ docker.network_name }}"

View File

@@ -16,7 +16,7 @@ services:
glance.url: https://{{ subdomains.home }}/ glance.url: https://{{ subdomains.home }}/
glance.description: Homepage app glance.description: Homepage app
glance.id: glance glance.id: glance
mag37.dockcheck.update: true
networks: networks:
default: default:
external: true external: true

View File

@@ -13,6 +13,7 @@ services:
glance.icon: si:gotify glance.icon: si:gotify
glance.url: "https://{{ subdomains.gotify }}/" glance.url: "https://{{ subdomains.gotify }}/"
glance.description: Push notification server glance.description: Push notification server
mag37.dockcheck.update: true
extra_hosts: extra_hosts:
- "{{ subdomains.auth }}:{{ docker.hairpin_ip }}" - "{{ subdomains.auth }}:{{ docker.hairpin_ip }}"
- "{{ subdomains.gotify_assistant }}:{{ docker.hairpin_ip }}" - "{{ subdomains.gotify_assistant }}:{{ docker.hairpin_ip }}"

View File

@@ -1,6 +1,6 @@
services: services:
gotosocial: gotosocial:
image: docker.io/superseriousbusiness/gotosocial:0.19.1 image: docker.io/superseriousbusiness/gotosocial:latest
container_name: gotosocial container_name: gotosocial
user: 1000:1000 user: 1000:1000
extra_hosts: extra_hosts:

View File

@@ -9,6 +9,7 @@ services:
glance.url: http://{{ network.docker_host_ip }}:5984 glance.url: http://{{ network.docker_host_ip }}:5984
glance.description: Obsidian note synchronization glance.description: Obsidian note synchronization
glance.id: obsidian-livesync glance.id: obsidian-livesync
mag37.dockcheck.update: true
environment: environment:
- SERVER_DOMAIN={{ network.docker_host_ip }} - SERVER_DOMAIN={{ network.docker_host_ip }}
- COUCHDB_USER={{ vault_obsidian.username }} - COUCHDB_USER={{ vault_obsidian.username }}

View File

@@ -9,6 +9,7 @@ services:
glance.url: https://netcup.porgy-porgy.ts.net:8384 glance.url: https://netcup.porgy-porgy.ts.net:8384
glance.description: Syncthing core glance.description: Syncthing core
glance.id: Syncthing glance.id: Syncthing
mag37.dockcheck.update: true
environment: environment:
- PUID=1000 - PUID=1000
- PGID=1000 - PGID=1000