asdadsasdasd
This commit is contained in:
232
.gitlab-ci.yml
232
.gitlab-ci.yml
@@ -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
1
config/stagingdemo.txt
Executable file
@@ -0,0 +1 @@
|
|||||||
|
Demo männ
|
||||||
45
schema.sql
Executable file
45
schema.sql
Executable 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)
|
||||||
|
);
|
||||||
Reference in New Issue
Block a user