chore: Sync MokoStandards 04.04.00 #109
114
.github/workflows/deploy-dev.yml
vendored
114
.github/workflows/deploy-dev.yml
vendored
@@ -22,7 +22,7 @@
|
|||||||
# INGROUP: MokoStandards.Deploy
|
# INGROUP: MokoStandards.Deploy
|
||||||
# REPO: https://github.com/mokoconsulting-tech/MokoStandards
|
# REPO: https://github.com/mokoconsulting-tech/MokoStandards
|
||||||
# PATH: /templates/workflows/shared/deploy-dev.yml
|
# PATH: /templates/workflows/shared/deploy-dev.yml
|
||||||
# VERSION: 04.01.00
|
# VERSION: 04.04.01
|
||||||
# BRIEF: SFTP deployment workflow for development server — synced to all governed repos
|
# BRIEF: SFTP deployment workflow for development server — synced to all governed repos
|
||||||
# NOTE: Synced via bulk-repo-sync to .github/workflows/deploy-dev.yml in all governed repos.
|
# NOTE: Synced via bulk-repo-sync to .github/workflows/deploy-dev.yml in all governed repos.
|
||||||
# Port is resolved in order: DEV_FTP_PORT variable → :port suffix in DEV_FTP_HOST → 22.
|
# Port is resolved in order: DEV_FTP_PORT variable → :port suffix in DEV_FTP_HOST → 22.
|
||||||
@@ -49,6 +49,7 @@ on:
|
|||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- 'dev/**'
|
- 'dev/**'
|
||||||
|
- 'rc/**'
|
||||||
- develop
|
- develop
|
||||||
- development
|
- development
|
||||||
paths:
|
paths:
|
||||||
@@ -57,6 +58,7 @@ on:
|
|||||||
types: [opened, synchronize, reopened, closed]
|
types: [opened, synchronize, reopened, closed]
|
||||||
branches:
|
branches:
|
||||||
- 'dev/**'
|
- 'dev/**'
|
||||||
|
- 'rc/**'
|
||||||
- develop
|
- develop
|
||||||
- development
|
- development
|
||||||
paths:
|
paths:
|
||||||
@@ -73,6 +75,9 @@ permissions:
|
|||||||
contents: read
|
contents: read
|
||||||
pull-requests: write
|
pull-requests: write
|
||||||
|
|
||||||
|
env:
|
||||||
|
FORCE_JAVASCRIPT_ACTIONS_TO_NODE24: true
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
check-permission:
|
check-permission:
|
||||||
name: Verify Deployment Permission
|
name: Verify Deployment Permission
|
||||||
@@ -347,8 +352,8 @@ jobs:
|
|||||||
|
|
||||||
# ── Platform-specific path safety guards ──────────────────────────────
|
# ── Platform-specific path safety guards ──────────────────────────────
|
||||||
PLATFORM=""
|
PLATFORM=""
|
||||||
if [ -f ".moko-standards" ]; then
|
MOKO_FILE=".github/.mokostandards"; [ ! -f "$MOKO_FILE" ] && MOKO_FILE=".mokostandards"; if [ -f "$MOKO_FILE" ]; then
|
||||||
PLATFORM=$(grep -E '^platform:' .moko-standards | sed 's/.*:[[:space:]]*//' | tr -d '"')
|
PLATFORM=$(grep -oP '^platform:.*' "$MOKO_FILE" 2>/dev/null || true)
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$PLATFORM" = "crm-module" ]; then
|
if [ "$PLATFORM" = "crm-module" ]; then
|
||||||
@@ -409,7 +414,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Setup PHP
|
- name: Setup PHP
|
||||||
if: steps.source.outputs.skip == 'false' && steps.remote.outputs.skip != 'true'
|
if: steps.source.outputs.skip == 'false' && steps.remote.outputs.skip != 'true'
|
||||||
uses: shivammathur/setup-php@44454db4f0199b8b9685a5d763dc37cbf79108e1 # v2.31.0
|
uses: shivammathur/setup-php@fcafdd6392932010c2bd5094439b8e33be2a8a09 # v2.37.0
|
||||||
with:
|
with:
|
||||||
php-version: '8.1'
|
php-version: '8.1'
|
||||||
tools: composer
|
tools: composer
|
||||||
@@ -420,14 +425,17 @@ jobs:
|
|||||||
GH_TOKEN: ${{ secrets.GH_TOKEN || github.token }}
|
GH_TOKEN: ${{ secrets.GH_TOKEN || github.token }}
|
||||||
COMPOSER_AUTH: '{"github-oauth":{"github.com":"${{ secrets.GH_TOKEN || github.token }}"}}'
|
COMPOSER_AUTH: '{"github-oauth":{"github.com":"${{ secrets.GH_TOKEN || github.token }}"}}'
|
||||||
run: |
|
run: |
|
||||||
git clone --depth 1 --quiet \
|
git clone --depth 1 --branch version/04.04 --quiet \
|
||||||
"https://x-access-token:${GH_TOKEN}@github.com/mokoconsulting-tech/MokoStandards.git" \
|
"https://x-access-token:${GH_TOKEN}@github.com/mokoconsulting-tech/MokoStandards.git" \
|
||||||
/tmp/mokostandards
|
/tmp/mokostandards
|
||||||
cd /tmp/mokostandards
|
cd /tmp/mokostandards
|
||||||
composer install --no-dev --no-interaction --quiet
|
composer install --no-dev --no-interaction --quiet
|
||||||
|
|
||||||
- name: Clear remote destination folder
|
- name: Clear remote destination folder (manual only)
|
||||||
if: steps.source.outputs.skip == 'false' && steps.remote.outputs.skip != 'true'
|
if: >-
|
||||||
|
steps.source.outputs.skip == 'false' &&
|
||||||
|
steps.remote.outputs.skip != 'true' &&
|
||||||
|
inputs.clear_remote == true
|
||||||
env:
|
env:
|
||||||
SFTP_HOST: ${{ steps.conn.outputs.host }}
|
SFTP_HOST: ${{ steps.conn.outputs.host }}
|
||||||
SFTP_PORT: ${{ steps.conn.outputs.port }}
|
SFTP_PORT: ${{ steps.conn.outputs.port }}
|
||||||
@@ -574,23 +582,87 @@ jobs:
|
|||||||
DEPLOY_ARGS+=(--key-passphrase "$SFTP_PASSWORD")
|
DEPLOY_ARGS+=(--key-passphrase "$SFTP_PASSWORD")
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# ── For Dolibarr (crm-module): set version to "development" before deploy ─
|
# Set platform version to "development" before deploy (Dolibarr + Joomla)
|
||||||
PLATFORM=""
|
php /tmp/mokostandards/api/cli/version_set_platform.php --path . --version development
|
||||||
if [ -f ".moko-standards" ]; then
|
|
||||||
PLATFORM=$(grep -E '^platform:' .moko-standards | sed 's/.*:[[:space:]]*//' | tr -d '"')
|
# Write update files — dev/** = development, rc/** = rc
|
||||||
|
PLATFORM=$(php /tmp/mokostandards/api/cli/platform_detect.php --path . 2>/dev/null || true)
|
||||||
|
REPO="${{ github.repository }}"
|
||||||
|
BRANCH="${{ github.ref_name }}"
|
||||||
|
|
||||||
|
# Determine stability tag from branch prefix
|
||||||
|
STABILITY="development"
|
||||||
|
VERSION_LABEL="development"
|
||||||
|
if [[ "$BRANCH" == rc/* ]]; then
|
||||||
|
STABILITY="rc"
|
||||||
|
VERSION_LABEL=$(php /tmp/mokostandards/api/cli/version_read.php --path . 2>/dev/null || echo "${BRANCH#rc/}")-rc
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$PLATFORM" = "crm-module" ]; then
|
if [ "$PLATFORM" = "crm-module" ]; then
|
||||||
echo "📦 Dolibarr dev deploy — setting module version to 'development'"
|
printf '%s' "$VERSION_LABEL" > update.txt
|
||||||
find "$SOURCE_DIR" -path "*/core/modules/mod*.class.php" -exec \
|
|
||||||
sed -i "s/\(\$this->version\s*=\s*\)['\"][^'\"]*['\"]/\1'development'/" {} + 2>/dev/null || true
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$PLATFORM" = "waas-component" ]; then
|
if [ "$PLATFORM" = "waas-component" ]; then
|
||||||
echo "📦 Joomla dev deploy — setting manifest version to 'development'"
|
MANIFEST=$(find . -maxdepth 2 -name "*.xml" -exec grep -l '<extension' {} \; 2>/dev/null | head -1 || true)
|
||||||
find "$SOURCE_DIR" -maxdepth 2 -name "*.xml" -exec grep -l '<extension' {} \; 2>/dev/null | while read -r manifest; do
|
if [ -n "$MANIFEST" ]; then
|
||||||
sed -i "s|<version>[^<]*</version>|<version>development</version>|" "$manifest" 2>/dev/null || true
|
EXT_NAME=$(grep -oP '<name>\K[^<]+' "$MANIFEST" 2>/dev/null | head -1 || echo "${{ github.event.repository.name }}")
|
||||||
done
|
EXT_TYPE=$(grep -oP '<extension[^>]+type="\K[^"]+' "$MANIFEST" 2>/dev/null || echo "component")
|
||||||
|
EXT_ELEMENT=$(grep -oP '<element>\K[^<]+' "$MANIFEST" 2>/dev/null | head -1 || basename "$MANIFEST" .xml)
|
||||||
|
EXT_CLIENT=$(grep -oP '<extension[^>]+client="\K[^"]+' "$MANIFEST" 2>/dev/null || echo "")
|
||||||
|
EXT_FOLDER=$(grep -oP '<extension[^>]+group="\K[^"]+' "$MANIFEST" 2>/dev/null || echo "")
|
||||||
|
TARGET_PLATFORM=$(grep -oP '<targetplatform[^/]*/>' "$MANIFEST" 2>/dev/null | head -1 || echo '<targetplatform name="joomla" version="((4\.[3-9])|(5\.[0-9]))" />')
|
||||||
|
|
||||||
|
CLIENT_TAG=""
|
||||||
|
if [ -n "$EXT_CLIENT" ]; then
|
||||||
|
CLIENT_TAG="<client>${EXT_CLIENT}</client>"
|
||||||
|
elif [ "$EXT_TYPE" = "module" ] || [ "$EXT_TYPE" = "plugin" ]; then
|
||||||
|
CLIENT_TAG="<client>site</client>"
|
||||||
|
fi
|
||||||
|
|
||||||
|
FOLDER_TAG=""
|
||||||
|
if [ -n "$EXT_FOLDER" ] && [ "$EXT_TYPE" = "plugin" ]; then
|
||||||
|
FOLDER_TAG="<folder>${EXT_FOLDER}</folder>"
|
||||||
|
fi
|
||||||
|
|
||||||
|
DOWNLOAD_URL="https://github.com/${REPO}/archive/refs/heads/${BRANCH}.zip"
|
||||||
|
|
||||||
|
cat > update.xml << 'DEVXML'
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<updates>
|
||||||
|
<update>
|
||||||
|
<name>EXT_NAME_PH</name>
|
||||||
|
<description>EXT_NAME_PH STABILITY_PH build</description>
|
||||||
|
<element>EXT_ELEMENT_PH</element>
|
||||||
|
<type>EXT_TYPE_PH</type>
|
||||||
|
<version>VERSION_LABEL_PH</version>
|
||||||
|
CLIENT_TAG_PH
|
||||||
|
FOLDER_TAG_PH
|
||||||
|
<tags>
|
||||||
|
<tag>STABILITY_PH</tag>
|
||||||
|
</tags>
|
||||||
|
<infourl title="EXT_NAME_PH">https://github.com/REPO_PH/tree/BRANCH_PH</infourl>
|
||||||
|
<downloads>
|
||||||
|
<downloadurl type="full" format="zip">DOWNLOAD_URL_PH</downloadurl>
|
||||||
|
</downloads>
|
||||||
|
TARGET_PLATFORM_PH
|
||||||
|
<maintainer>Moko Consulting</maintainer>
|
||||||
|
<maintainerurl>https://mokoconsulting.tech</maintainerurl>
|
||||||
|
</update>
|
||||||
|
</updates>
|
||||||
|
DEVXML
|
||||||
|
sed -i "s|EXT_NAME_PH|${EXT_NAME}|g" update.xml
|
||||||
|
sed -i "s|EXT_ELEMENT_PH|${EXT_ELEMENT}|g" update.xml
|
||||||
|
sed -i "s|EXT_TYPE_PH|${EXT_TYPE}|g" update.xml
|
||||||
|
sed -i "s|CLIENT_TAG_PH|${CLIENT_TAG}|g" update.xml
|
||||||
|
sed -i "s|FOLDER_TAG_PH|${FOLDER_TAG}|g" update.xml
|
||||||
|
sed -i "s|REPO_PH|${REPO}|g" update.xml
|
||||||
|
sed -i "s|BRANCH_PH|${BRANCH}|g" update.xml
|
||||||
|
sed -i "s|DOWNLOAD_URL_PH|${DOWNLOAD_URL}|g" update.xml
|
||||||
|
sed -i "s|TARGET_PLATFORM_PH|${TARGET_PLATFORM}|g" update.xml
|
||||||
|
sed -i "s|VERSION_LABEL_PH|${VERSION_LABEL}|g" update.xml
|
||||||
|
sed -i "s|STABILITY_PH|${STABILITY}|g" update.xml
|
||||||
|
sed -i '/^[[:space:]]*$/d' update.xml
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
php /tmp/mokostandards/api/deploy/deploy-sftp.php "${DEPLOY_ARGS[@]}"
|
php /tmp/mokostandards/api/deploy/deploy-sftp.php "${DEPLOY_ARGS[@]}"
|
||||||
@@ -641,7 +713,7 @@ jobs:
|
|||||||
--force 2>/dev/null || true
|
--force 2>/dev/null || true
|
||||||
|
|
||||||
# Look for an existing open deploy-failure issue
|
# Look for an existing open deploy-failure issue
|
||||||
EXISTING=$(gh api "repos/${REPO}/issues?labels=${LABEL}&state=open&per_page=1" \
|
EXISTING=$(gh api "repos/${REPO}/issues?labels=${LABEL}&state=all&per_page=1&sort=created&direction=desc" \
|
||||||
--jq '.[0].number' 2>/dev/null)
|
--jq '.[0].number' 2>/dev/null)
|
||||||
|
|
||||||
if [ -n "$EXISTING" ] && [ "$EXISTING" != "null" ]; then
|
if [ -n "$EXISTING" ] && [ "$EXISTING" != "null" ]; then
|
||||||
@@ -649,14 +721,16 @@ jobs:
|
|||||||
-X PATCH \
|
-X PATCH \
|
||||||
-f title="$TITLE" \
|
-f title="$TITLE" \
|
||||||
-f body="$BODY" \
|
-f body="$BODY" \
|
||||||
|
-f state="open" \
|
||||||
--silent
|
--silent
|
||||||
echo "📋 Failure issue #${EXISTING} updated: ${REPO}" >> "$GITHUB_STEP_SUMMARY"
|
echo "📋 Failure issue #${EXISTING} updated/reopened: ${REPO}" >> "$GITHUB_STEP_SUMMARY"
|
||||||
else
|
else
|
||||||
gh issue create \
|
gh issue create \
|
||||||
--repo "$REPO" \
|
--repo "$REPO" \
|
||||||
--title "$TITLE" \
|
--title "$TITLE" \
|
||||||
--body "$BODY" \
|
--body "$BODY" \
|
||||||
--label "$LABEL" \
|
--label "$LABEL" \
|
||||||
|
--assignee "jmiller-moko" \
|
||||||
| tee -a "$GITHUB_STEP_SUMMARY"
|
| tee -a "$GITHUB_STEP_SUMMARY"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user