ThreeGate/tools/validate_and_quarantine_too...

25 lines
876 B
Bash

#!/usr/bin/env bash
set -euo pipefail
REQ_DIR="${REQ_DIR:-./infra/volumes/tool-exec/requests_in}"
QUAR_DIR="${QUAR_DIR:-./infra/volumes/handoff/quarantine}"
VALIDATOR="${VALIDATOR:-./tools/validate_tool_request.py}"
mkdir -p "${REQ_DIR}" "${QUAR_DIR}"
shopt -s nullglob
for f in "${REQ_DIR}"/*.md; do
echo "Validating tool request: ${f}"
if "${VALIDATOR}" "${f}" >/tmp/threegate_toolreq_validate.out 2>/tmp/threegate_toolreq_validate.err; then
echo "ACCEPT: ${f}"
else
echo "REJECT: ${f}"
base="$(basename "${f}")"
stamp="$(date -u +%Y%m%d-%H%M%SZ)"
mkdir -p "${QUAR_DIR}/${stamp}-${base}"
mv -- "${f}" "${QUAR_DIR}/${stamp}-${base}/"
mv -- /tmp/threegate_toolreq_validate.out "${QUAR_DIR}/${stamp}-${base}/validator.out" || true
mv -- /tmp/threegate_toolreq_validate.err "${QUAR_DIR}/${stamp}-${base}/validator.err" || true
fi
done