122 lines
3.1 KiB
YAML
122 lines
3.1 KiB
YAML
apiVersion: v1
|
|
kind: ConfigMap
|
|
metadata:
|
|
name: rosdump-config
|
|
data:
|
|
script.sh: |
|
|
#!/bin/bash
|
|
set -e
|
|
mkdir -p /root/.ssh
|
|
cp /config/ssh_identity /root/.ssh/id_ecdsa
|
|
chmod 600 /root/.ssh/id_ed25519
|
|
sleep 100
|
|
if [ -d rosdump ]; then
|
|
echo "Pulling Git repo"
|
|
cd rosdump
|
|
git pull
|
|
else
|
|
echo "Cloning Git repo"
|
|
git clone git@git.k-space.ee:k-space/rosdump.git
|
|
cd rosdump
|
|
fi
|
|
git rm *.k-space.ee
|
|
for target in $(cat /config/targets | grep -v '^#'); do
|
|
echo "Exporting configuration for $target"
|
|
ssh rosdump@$target '/export' | grep -v '^# serial number =' | grep -v '^#.* by RouterOS' > $target
|
|
git add $target
|
|
done
|
|
if [[ `git status --porcelain` ]]; then
|
|
echo "Attempting Git check in"
|
|
git commit -m "$(git diff --cached --shortstat)"
|
|
git push
|
|
else
|
|
echo "No changes to commit"
|
|
fi
|
|
targets: |
|
|
router.mgmt.k-space.ee
|
|
sw_core01.mgmt.k-space.ee
|
|
sw_core02.mgmt.k-space.ee
|
|
sw_mgmt.mgmt.k-space.ee
|
|
sw_poe.mgmt.k-space.ee
|
|
sw_ha.mgmt.k-space.ee
|
|
sw_cyber.mgmt.k-space.ee
|
|
sw_chaos.mgmt.k-space.ee
|
|
sw_asocial.mgmt.k-space.ee
|
|
sw_kitchen.mgmt.k-space.ee
|
|
---
|
|
apiVersion: batch/v1
|
|
kind: CronJob
|
|
metadata:
|
|
name: rosdump-cronjob
|
|
spec:
|
|
schedule: "0 * * * *"
|
|
concurrencyPolicy: Forbid
|
|
jobTemplate:
|
|
spec:
|
|
activeDeadlineSeconds: 300
|
|
template:
|
|
spec:
|
|
restartPolicy: OnFailure
|
|
containers:
|
|
- name: rosdump
|
|
image: codemowers/git
|
|
imagePullPolicy: IfNotPresent
|
|
args:
|
|
- sh
|
|
- /config/script.sh
|
|
volumeMounts:
|
|
- name: config
|
|
mountPath: /config
|
|
volumes:
|
|
- name: config
|
|
projected:
|
|
sources:
|
|
- secret:
|
|
name: rosdump-secrets
|
|
items:
|
|
- key: ssh_identity
|
|
path: ssh_identity
|
|
mode: 0600
|
|
- configMap:
|
|
name: rosdump-known-hosts
|
|
items:
|
|
- key: ssh_known_hosts
|
|
path: ssh_known_hosts
|
|
- configMap:
|
|
name: rosdump-config
|
|
---
|
|
apiVersion: networking.k8s.io/v1
|
|
kind: NetworkPolicy
|
|
metadata:
|
|
name: rosdump
|
|
spec:
|
|
podSelector: {}
|
|
policyTypes:
|
|
- Egress
|
|
egress:
|
|
- to:
|
|
- namespaceSelector:
|
|
matchLabels:
|
|
kubernetes.io/metadata.name: gitea
|
|
- ipBlock:
|
|
cidr: 172.23.0.0/24
|
|
- ipBlock:
|
|
cidr: 100.102.1.0/24
|
|
|
|
---
|
|
apiVersion: monitoring.coreos.com/v1
|
|
kind: PrometheusRule
|
|
metadata:
|
|
name: rosdump
|
|
spec:
|
|
groups:
|
|
- name: rosdump
|
|
rules:
|
|
- alert: MikrotikBackupsBroken
|
|
expr: absent(kube_cronjob_status_last_successful_time{cronjob="rosdump-cronjob"}) or time() - kube_cronjob_status_last_successful_time{cronjob="rosdump-cronjob"} > 3600
|
|
for: 4h
|
|
labels:
|
|
severity: warning
|
|
annotations:
|
|
summary: Mikrotik backups are broken
|