asdadsasdasd

This commit is contained in:
2026-01-22 00:44:18 +01:00
parent 526db3953a
commit a3769f5075
3 changed files with 208 additions and 100 deletions

View File

@@ -1,79 +1,114 @@
stages: stages:
- deploy - deploy
# -----------------------------------------
# Globale Variablen
# -----------------------------------------
variables:
BASE_DIRS: "src public api partials tools"
CONFIG_BASE_DIR: "config"
# Standard-Image für alle Jobs
default:
image: usbcheck/ci-usbcheck-deploy:latest
# ----------------------------------------- # -----------------------------------------
# Deployment auf STAGING # Deployment auf STAGING
# ----------------------------------------- # -----------------------------------------
deploy:staging: deploy:staging:
stage: deploy stage: deploy
image: alpine:3.20
variables:
TARGET_PATH: "${FTP_PATH_STAGING}"
CONFIG_ENV_DIR: "config/staging"
before_script: before_script:
- echo "📡 Installing lftp..."
- apk add --no-cache lftp
- echo "📂 CI Workspace:" - echo "📂 CI Workspace:"
- pwd - pwd
- echo "host ${FTP_HOST}"
- echo "path ${FTP_PATH_STAGING}"
- echo "user ${FTP_USER}"
- ls -la - ls -la
- echo "📂 Inhalt von src/:" - echo "📁 Prüfe & zeige Projektverzeichnisse:"
- ls -la src/ || echo "⚠️ src/ existiert nicht!"
- echo "📂 Inhalt von public/:"
- ls -la public/ || echo "⚠️ public/ existiert nicht!"
- echo "📂 Inhalt von config/:"
- ls -la config/ || echo "⚠️ config/ existiert nicht!"
- echo "📂 Inhalt von config/staging/:"
- ls -la config/staging/ || echo "⚠️ config/staging/ existiert nicht!"
script:
- | - |
set -e for d in $BASE_DIRS $CONFIG_BASE_DIR $CONFIG_ENV_DIR; do
echo "----------------------------------------"
# Sicherstellen, dass Basisverzeichnisse existieren if [ -d "$d" ]; then
for d in src public config config/staging; do echo "📂 Inhalt von $d/:"
if [ ! -d "$d" ]; then ls -la "$d/"
echo "❌ Verzeichnis '$d/' fehlt im Repo! Abbruch." else
exit 1 echo "⚠️ Verzeichnis '$d' existiert nicht!"
fi fi
done done
echo "🚀 Deploy STAGING → ${FTP_HOST}:${FTP_PATH_STAGING}" script:
- |
echo "📁 Prüfe lokale Basisverzeichnisse..."
MISSING=0
echo "🔁 Sync src/ → ${FTP_PATH_STAGING}src/" for d in $BASE_DIRS; do
if [ ! -d "$d" ]; then
echo "❌ Verzeichnis '$d/' fehlt im Repo!"
MISSING=1
fi
done
if [ ! -d "$CONFIG_BASE_DIR" ]; then
echo "❌ Basis-Konfig-Verzeichnis '$CONFIG_BASE_DIR/' fehlt!"
MISSING=1
fi
if [ ! -d "$CONFIG_ENV_DIR" ]; then
echo "❌ Env-Konfiguration '$CONFIG_ENV_DIR/' fehlt!"
MISSING=1
fi
if [ "$MISSING" -ne 0 ]; then
echo "⛔ Abbruch wegen fehlender Verzeichnisse."
exit 1
fi
echo "🚀 Deploy ${CI_ENVIRONMENT_NAME} → ${FTP_HOST}:${TARGET_PATH}"
for d in $BASE_DIRS; do
echo "🔁 Sync ${d}/ → ${TARGET_PATH}${d}/"
lftp -u "${FTP_USER}","${FTP_PASSWORD}" "${FTP_HOST}" -e " lftp -u "${FTP_USER}","${FTP_PASSWORD}" "${FTP_HOST}" -e "
set ftp:ssl-force true; set ftp:ssl-force true;
set ftp:passive-mode true; set ftp:passive-mode true;
set ftp:ssl-protect-data true; set ftp:ssl-protect-data true;
set ssl:verify-certificate no; set ssl:verify-certificate no;
mirror -R --delete --exclude .gitkeep src/ ${FTP_PATH_STAGING}src/; mirror -R --delete --exclude .gitkeep ${d}/ ${TARGET_PATH}${d}/;
bye bye
" " || { echo "❌ Upload für Verzeichnis '${d}' fehlgeschlagen."; exit 1; }
done
echo "🔁 Sync public/ → ${FTP_PATH_STAGING}public/" echo "🧩 Baue gemischtes Config-Verzeichnis (config/*.php + ${CONFIG_ENV_DIR})..."
rm -rf .ci_config_deploy
mkdir -p .ci_config_deploy
if [ -d "${CONFIG_BASE_DIR}" ]; then
for f in ${CONFIG_BASE_DIR}/*.php; do
if [ -f "$f" ]; then
echo " Basis-Config-Datei: $f"
cp "$f" .ci_config_deploy/
fi
done
fi
if [ -d "${CONFIG_ENV_DIR}" ]; then
echo " Env-Config aus ${CONFIG_ENV_DIR}/"
cp -R ${CONFIG_ENV_DIR}/. .ci_config_deploy/
fi
echo "🔁 Sync .ci_config_deploy/ → ${TARGET_PATH}${CONFIG_BASE_DIR}/"
lftp -u "${FTP_USER}","${FTP_PASSWORD}" "${FTP_HOST}" -e " lftp -u "${FTP_USER}","${FTP_PASSWORD}" "${FTP_HOST}" -e "
set ftp:ssl-force true; set ftp:ssl-force true;
set ftp:passive-mode true; set ftp:passive-mode true;
set ftp:ssl-protect-data true; set ftp:ssl-protect-data true;
set ssl:verify-certificate no; set ssl:verify-certificate no;
mirror -R --delete --exclude .gitkeep public/ ${FTP_PATH_STAGING}public/; lcd .ci_config_deploy;
mirror -R --delete --exclude .gitkeep ./ ${TARGET_PATH}${CONFIG_BASE_DIR}/;
bye bye
" " || { echo "❌ Upload für gemischtes Config-Verzeichnis fehlgeschlagen."; exit 1; }
echo "🔁 Sync config/staging/ (nur Inhalt) → ${FTP_PATH_STAGING}config/" echo "✅ Deploy ${CI_ENVIRONMENT_NAME} abgeschlossen."
lftp -u "${FTP_USER}","${FTP_PASSWORD}" "${FTP_HOST}" -e "
set ftp:ssl-force true;
set ftp:passive-mode true;
set ftp:ssl-protect-data true;
set ssl:verify-certificate no;
lcd config/staging;
mirror -R --delete --exclude .gitkeep ./ ${FTP_PATH_STAGING}config/;
bye
"
echo "✅ Deploy STAGING abgeschlossen."
environment: environment:
name: staging name: staging
@@ -89,71 +124,98 @@ deploy:staging:
# ----------------------------------------- # -----------------------------------------
deploy:production: deploy:production:
stage: deploy stage: deploy
image: alpine:3.20
variables:
TARGET_PATH: "${FTP_PATH_PROD}"
CONFIG_ENV_DIR: "config/prod"
before_script: before_script:
- echo "📡 Installing lftp..."
- apk add --no-cache lftp
- echo "📂 CI Workspace:" - echo "📂 CI Workspace:"
- pwd - pwd
- ls -la - ls -la
- echo "📁 Prüfe & zeige Projektverzeichnisse:"
- echo "📂 Inhalt von src/:"
- ls -la src/ || echo "⚠️ src/ existiert nicht!"
- echo "📂 Inhalt von public/:"
- ls -la public/ || echo "⚠️ public/ existiert nicht!"
- echo "📂 Inhalt von config/:"
- ls -la config/ || echo "⚠️ config/ existiert nicht!"
- echo "📂 Inhalt von config/prod/:"
- ls -la config/prod/ || echo "⚠️ config/prod/ existiert nicht!"
script:
- | - |
set -e for d in $BASE_DIRS $CONFIG_BASE_DIR $CONFIG_ENV_DIR; do
echo "----------------------------------------"
# Sicherstellen, dass Basisverzeichnisse existieren if [ -d "$d" ]; then
for d in src public config config/prod; do echo "📂 Inhalt von $d/:"
if [ ! -d "$d" ]; then ls -la "$d/"
echo "❌ Verzeichnis '$d/' fehlt im Repo! Abbruch." else
exit 1 echo "⚠️ Verzeichnis '$d' existiert nicht!"
fi fi
done done
echo "🚀 Deploy PRODUCTION → ${FTP_HOST}:${FTP_PATH_PROD}" script:
- |
echo "📁 Prüfe lokale Basisverzeichnisse..."
MISSING=0
echo "🔁 Sync src/ → ${FTP_PATH_PROD}src/" for d in $BASE_DIRS; do
if [ ! -d "$d" ]; then
echo "❌ Verzeichnis '$d/' fehlt im Repo!"
MISSING=1
fi
done
if [ ! -d "$CONFIG_BASE_DIR" ]; then
echo "❌ Basis-Konfig-Verzeichnis '$CONFIG_BASE_DIR/' fehlt!"
MISSING=1
fi
if [ ! -d "$CONFIG_ENV_DIR" ]; then
echo "❌ Env-Konfiguration '$CONFIG_ENV_DIR/' fehlt!"
MISSING=1
fi
if [ "$MISSING" -ne 0 ]; then
echo "⛔ Abbruch wegen fehlender Verzeichnisse."
exit 1
fi
echo "🚀 Deploy ${CI_ENVIRONMENT_NAME} → ${FTP_HOST}:${TARGET_PATH}"
for d in $BASE_DIRS; do
echo "🔁 Sync ${d}/ → ${TARGET_PATH}${d}/"
lftp -u "${FTP_USER}","${FTP_PASSWORD}" "${FTP_HOST}" -e " lftp -u "${FTP_USER}","${FTP_PASSWORD}" "${FTP_HOST}" -e "
set ftp:ssl-force true; set ftp:ssl-force true;
set ftp:passive-mode true; set ftp:passive-mode true;
set ftp:ssl-protect-data true; set ftp:ssl-protect-data true;
set ssl:verify-certificate no; set ssl:verify-certificate no;
mirror -R --delete --exclude .gitkeep src/ ${FTP_PATH_PROD}src/; mirror -R --delete --exclude .gitkeep ${d}/ ${TARGET_PATH}${d}/;
bye bye
" " || { echo "❌ Upload für Verzeichnis '${d}' fehlgeschlagen."; exit 1; }
done
echo "🔁 Sync public/ → ${FTP_PATH_PROD}public/" echo "🧩 Baue gemischtes Config-Verzeichnis (config/*.php + ${CONFIG_ENV_DIR})..."
rm -rf .ci_config_deploy
mkdir -p .ci_config_deploy
if [ -d "${CONFIG_BASE_DIR}" ]; then
for f in ${CONFIG_BASE_DIR}/*.php; do
if [ -f "$f" ]; then
echo " Basis-Config-Datei: $f"
cp "$f" .ci_config_deploy/
fi
done
fi
if [ -d "${CONFIG_ENV_DIR}" ]; then
echo " Env-Config aus ${CONFIG_ENV_DIR}/"
cp -R ${CONFIG_ENV_DIR}/. .ci_config_deploy/
fi
echo "🔁 Sync .ci_config_deploy/ → ${TARGET_PATH}${CONFIG_BASE_DIR}/"
lftp -u "${FTP_USER}","${FTP_PASSWORD}" "${FTP_HOST}" -e " lftp -u "${FTP_USER}","${FTP_PASSWORD}" "${FTP_HOST}" -e "
set ftp:ssl-force true; set ftp:ssl-force true;
set ftp:passive-mode true; set ftp:passive-mode true;
set ftp:ssl-protect-data true; set ftp:ssl-protect-data true;
set ssl:verify-certificate no; set ssl:verify-certificate no;
mirror -R --delete --exclude .gitkeep public/ ${FTP_PATH_PROD}public/; lcd .ci_config_deploy;
mirror -R --delete --exclude .gitkeep ./ ${TARGET_PATH}${CONFIG_BASE_DIR}/;
bye bye
" " || { echo "❌ Upload für gemischtes Config-Verzeichnis fehlgeschlagen."; exit 1; }
echo "🔁 Sync config/prod/ (nur Inhalt) → ${FTP_PATH_PROD}config/" echo "✅ Deploy ${CI_ENVIRONMENT_NAME} abgeschlossen."
lftp -u "${FTP_USER}","${FTP_PASSWORD}" "${FTP_HOST}" -e "
set ftp:ssl-force true;
set ftp:passive-mode true;
set ftp:ssl-protect-data true;
set ssl:verify-certificate no;
lcd config/prod;
mirror -R --delete --exclude .gitkeep ./ ${FTP_PATH_PROD}config/;
bye
"
echo "✅ Deploy PRODUCTION abgeschlossen."
environment: environment:
name: production name: production

1
config/stagingdemo.txt Executable file
View File

@@ -0,0 +1 @@
Demo männ

45
schema.sql Executable file
View File

@@ -0,0 +1,45 @@
-- schema.sql
-- Datenbank-Schema für 3D-Druck Materialdatenbank
CREATE TABLE materials (
id INT AUTO_INCREMENT PRIMARY KEY,
code VARCHAR(50) NOT NULL,
name VARCHAR(150) NOT NULL,
short_desc VARCHAR(255) NULL,
properties TEXT NULL,
tg_celsius DECIMAL(5,1) NULL,
nozzle_req VARCHAR(150) NULL,
plate_req VARCHAR(150) NULL,
extra_req VARCHAR(255) NULL,
application TEXT NULL,
kid_safety ENUM('safe','limited','no') DEFAULT 'limited',
emission ENUM('low','medium','high') DEFAULT 'low',
is_active TINYINT(1) DEFAULT 1,
UNIQUE KEY uq_material_code (code)
);
CREATE TABLE printers (
id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(150) NOT NULL,
brand VARCHAR(100) NULL,
model_code VARCHAR(100) NULL,
max_nozzle_temp INT NULL,
max_bed_temp INT NULL,
chamber TINYINT(1) DEFAULT 0,
build_volume VARCHAR(50) NULL,
notes TEXT NULL,
is_active TINYINT(1) DEFAULT 1
);
CREATE TABLE printer_material_support (
id INT AUTO_INCREMENT PRIMARY KEY,
printer_id INT NOT NULL,
material_id INT NOT NULL,
support_level ENUM('full','partial','with_addon','no') NOT NULL DEFAULT 'no',
partial_reason VARCHAR(255) NULL,
extra_info VARCHAR(255) NULL,
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
CONSTRAINT fk_pms_printer FOREIGN KEY (printer_id) REFERENCES printers(id) ON DELETE CASCADE,
CONSTRAINT fk_pms_material FOREIGN KEY (material_id) REFERENCES materials(id) ON DELETE CASCADE,
UNIQUE KEY uq_printer_material (printer_id, material_id)
);