Compare commits
10 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| a4df3a651d | |||
| 785ffd85a3 | |||
| 71da4af64b | |||
| 4d5711c304 | |||
| 1a4bb32c6c | |||
| 13a526d6be | |||
| babdb9e390 | |||
| 57c9ea600b | |||
| afffef78bd | |||
| 720f008050 |
@@ -7,7 +7,7 @@
|
|||||||
# INGROUP: mokocli.Release
|
# INGROUP: mokocli.Release
|
||||||
# REPO: https://git.mokoconsulting.tech/mokoconsulting-tech/mokocli
|
# REPO: https://git.mokoconsulting.tech/mokoconsulting-tech/mokocli
|
||||||
# PATH: /templates/workflows/universal/auto-release.yml.template
|
# PATH: /templates/workflows/universal/auto-release.yml.template
|
||||||
# VERSION: 05.00.00
|
# VERSION: 05.01.00
|
||||||
# BRIEF: Universal build & release � detects platform from manifest.xml
|
# BRIEF: Universal build & release � detects platform from manifest.xml
|
||||||
#
|
#
|
||||||
# +=======================================================================+
|
# +=======================================================================+
|
||||||
@@ -75,6 +75,7 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
token: ${{ secrets.MOKOGITEA_TOKEN }}
|
token: ${{ secrets.MOKOGITEA_TOKEN }}
|
||||||
fetch-depth: 1
|
fetch-depth: 1
|
||||||
|
submodules: recursive
|
||||||
|
|
||||||
- name: Setup mokocli tools
|
- name: Setup mokocli tools
|
||||||
env:
|
env:
|
||||||
@@ -173,6 +174,7 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
token: ${{ secrets.MOKOGITEA_TOKEN }}
|
token: ${{ secrets.MOKOGITEA_TOKEN }}
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
|
submodules: recursive
|
||||||
|
|
||||||
- name: Configure git for bot pushes
|
- name: Configure git for bot pushes
|
||||||
run: |
|
run: |
|
||||||
|
|||||||
@@ -1,126 +0,0 @@
|
|||||||
# Copyright (C) 2026 Moko Consulting <hello@mokoconsulting.tech>
|
|
||||||
#
|
|
||||||
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
||||||
#
|
|
||||||
# FILE INFORMATION
|
|
||||||
# DEFGROUP: Gitea.Workflow
|
|
||||||
# INGROUP: MokoStandards.Deploy
|
|
||||||
# REPO: https://git.mokoconsulting.tech/MokoConsulting/MokoStandards-API
|
|
||||||
# PATH: /templates/workflows/joomla/deploy-manual.yml.template
|
|
||||||
# VERSION: 04.07.00
|
|
||||||
# BRIEF: Manual SFTP deploy to dev server for Joomla repos
|
|
||||||
|
|
||||||
name: "Universal: Deploy to Dev (Manual)"
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
inputs:
|
|
||||||
clear_remote:
|
|
||||||
description: 'Delete all remote files before uploading'
|
|
||||||
required: false
|
|
||||||
default: 'false'
|
|
||||||
type: boolean
|
|
||||||
|
|
||||||
env:
|
|
||||||
FORCE_JAVASCRIPT_ACTIONS_TO_NODE24: true
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
deploy:
|
|
||||||
name: SFTP Deploy to Dev
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: Checkout repository
|
|
||||||
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6
|
|
||||||
|
|
||||||
- name: Setup PHP
|
|
||||||
run: |
|
|
||||||
php -v && composer --version
|
|
||||||
|
|
||||||
- name: Setup MokoStandards tools
|
|
||||||
env:
|
|
||||||
MOKOGITEA_TOKEN: ${{ secrets.MOKOGITEA_TOKEN || github.token }}
|
|
||||||
MOKO_CLONE_TOKEN: ${{ secrets.MOKOGITEA_TOKEN || github.token }}
|
|
||||||
MOKO_CLONE_HOST: ${{ secrets.MOKOGITEA_TOKEN && 'git.mokoconsulting.tech/MokoConsulting' || 'github.com/mokoconsulting-tech' }}
|
|
||||||
COMPOSER_AUTH: '{"github-oauth":{"github.com":"${{ secrets.MOKOGITEA_TOKEN || github.token }}"}}'
|
|
||||||
run: |
|
|
||||||
git clone --depth 1 --branch main --quiet \
|
|
||||||
"https://x-access-token:${MOKO_CLONE_TOKEN}@${MOKO_CLONE_HOST}/MokoStandards-API.git" \
|
|
||||||
/tmp/mokostandards-api 2>/dev/null || true
|
|
||||||
if [ -d "/tmp/mokostandards-api" ] && [ -f "/tmp/mokostandards-api/composer.json" ]; then
|
|
||||||
cd /tmp/mokostandards-api && composer install --no-dev --no-interaction --quiet 2>/dev/null || true
|
|
||||||
fi
|
|
||||||
|
|
||||||
- name: Check FTP configuration
|
|
||||||
id: check
|
|
||||||
env:
|
|
||||||
HOST: ${{ vars.DEV_FTP_HOST }}
|
|
||||||
PATH_VAR: ${{ vars.DEV_FTP_PATH }}
|
|
||||||
PORT: ${{ vars.DEV_FTP_PORT }}
|
|
||||||
run: |
|
|
||||||
if [ -z "$HOST" ] || [ -z "$PATH_VAR" ]; then
|
|
||||||
echo "DEV_FTP_HOST or DEV_FTP_PATH not configured -- cannot deploy"
|
|
||||||
echo "skip=true" >> "$GITHUB_OUTPUT"
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
echo "skip=false" >> "$GITHUB_OUTPUT"
|
|
||||||
echo "host=$HOST" >> "$GITHUB_OUTPUT"
|
|
||||||
|
|
||||||
REMOTE="${PATH_VAR%/}"
|
|
||||||
echo "remote=$REMOTE" >> "$GITHUB_OUTPUT"
|
|
||||||
|
|
||||||
[ -z "$PORT" ] && PORT="22"
|
|
||||||
echo "port=$PORT" >> "$GITHUB_OUTPUT"
|
|
||||||
|
|
||||||
- name: Deploy via SFTP
|
|
||||||
if: steps.check.outputs.skip != 'true'
|
|
||||||
env:
|
|
||||||
SFTP_KEY: ${{ secrets.DEV_FTP_KEY }}
|
|
||||||
SFTP_PASS: ${{ secrets.DEV_FTP_PASSWORD }}
|
|
||||||
SFTP_USER: ${{ vars.DEV_FTP_USERNAME }}
|
|
||||||
run: |
|
|
||||||
SOURCE_DIR="src"
|
|
||||||
[ ! -d "$SOURCE_DIR" ] && SOURCE_DIR="htdocs"
|
|
||||||
[ ! -d "$SOURCE_DIR" ] && { echo "No src/ or htdocs/ -- nothing to deploy"; exit 0; }
|
|
||||||
|
|
||||||
printf '{"host":"%s","port":%s,"username":"%s","remotePath":"%s"' \
|
|
||||||
"${{ steps.check.outputs.host }}" "${{ steps.check.outputs.port }}" "$SFTP_USER" "${{ steps.check.outputs.remote }}" \
|
|
||||||
> /tmp/sftp-config.json
|
|
||||||
|
|
||||||
if [ -n "$SFTP_KEY" ]; then
|
|
||||||
echo "$SFTP_KEY" > /tmp/deploy_key
|
|
||||||
chmod 600 /tmp/deploy_key
|
|
||||||
printf ',"privateKeyPath":"/tmp/deploy_key"}' >> /tmp/sftp-config.json
|
|
||||||
else
|
|
||||||
printf ',"password":"%s"}' "$SFTP_PASS" >> /tmp/sftp-config.json
|
|
||||||
fi
|
|
||||||
|
|
||||||
DEPLOY_ARGS=(--path . --src-dir "$SOURCE_DIR" --config /tmp/sftp-config.json)
|
|
||||||
[ "${{ inputs.clear_remote }}" = "true" ] && DEPLOY_ARGS+=(--clear-remote)
|
|
||||||
|
|
||||||
PLATFORM=$(php /tmp/mokostandards-api/cli/platform_detect.php --path . 2>/dev/null || true)
|
|
||||||
if [ "$PLATFORM" = "waas-component" ] && [ -f "/tmp/mokostandards-api/deploy/deploy-joomla.php" ]; then
|
|
||||||
php /tmp/mokostandards-api/deploy/deploy-joomla.php "${DEPLOY_ARGS[@]}"
|
|
||||||
else
|
|
||||||
php /tmp/mokostandards-api/deploy/deploy-sftp.php "${DEPLOY_ARGS[@]}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
rm -f /tmp/deploy_key /tmp/sftp-config.json
|
|
||||||
|
|
||||||
- name: Summary
|
|
||||||
if: always()
|
|
||||||
run: |
|
|
||||||
if [ "${{ steps.check.outputs.skip }}" = "true" ]; then
|
|
||||||
echo "### Deploy Skipped -- FTP not configured" >> $GITHUB_STEP_SUMMARY
|
|
||||||
else
|
|
||||||
echo "### Manual Dev Deploy Complete" >> $GITHUB_STEP_SUMMARY
|
|
||||||
echo "" >> $GITHUB_STEP_SUMMARY
|
|
||||||
echo "| Field | Value |" >> $GITHUB_STEP_SUMMARY
|
|
||||||
echo "|-------|-------|" >> $GITHUB_STEP_SUMMARY
|
|
||||||
echo "| Host | \`${{ steps.check.outputs.host }}\` |" >> $GITHUB_STEP_SUMMARY
|
|
||||||
echo "| Remote | \`${{ steps.check.outputs.remote }}\` |" >> $GITHUB_STEP_SUMMARY
|
|
||||||
echo "| Clear | ${{ inputs.clear_remote }} |" >> $GITHUB_STEP_SUMMARY
|
|
||||||
fi
|
|
||||||
@@ -5,7 +5,7 @@
|
|||||||
# FILE INFORMATION
|
# FILE INFORMATION
|
||||||
# DEFGROUP: Gitea.Workflow
|
# DEFGROUP: Gitea.Workflow
|
||||||
# INGROUP: mokocli.Automation
|
# INGROUP: mokocli.Automation
|
||||||
# VERSION: 01.45.07
|
# VERSION: 01.00.00
|
||||||
# BRIEF: Auto-create feature branch when an issue is opened
|
# BRIEF: Auto-create feature branch when an issue is opened
|
||||||
|
|
||||||
name: "Universal: Issue Branch"
|
name: "Universal: Issue Branch"
|
||||||
|
|||||||
+8
-127
@@ -1,7 +1,13 @@
|
|||||||
# Changelog
|
# Changelog
|
||||||
|
|
||||||
## [Unreleased]
|
## [Unreleased]
|
||||||
|
|
||||||
|
## [01.45.00] --- 2026-06-28
|
||||||
|
|
||||||
|
|
||||||
|
## [01.45.00] --- 2026-06-28
|
||||||
|
|
||||||
|
## [01.43.35] --- 2026-06-28
|
||||||
|
|
||||||
### Added
|
### Added
|
||||||
- Customizable restore script filename per backup profile (reduces discoverability on remote servers)
|
- Customizable restore script filename per backup profile (reduces discoverability on remote servers)
|
||||||
- MokoRestore standalone mode: multi-ZIP selector when multiple backup archives are present
|
- MokoRestore standalone mode: multi-ZIP selector when multiple backup archives are present
|
||||||
@@ -17,6 +23,7 @@
|
|||||||
- MokoRestore cleanup and security messages now reference the actual script filename instead of hardcoded "restore.php"
|
- MokoRestore cleanup and security messages now reference the actual script filename instead of hardcoded "restore.php"
|
||||||
|
|
||||||
### Fixed
|
### Fixed
|
||||||
|
- SSH key indicator detection and missing delete language key
|
||||||
- Bootstrap 5 modal conversion for snapshots view (data-bs-dismiss, modal-footer, getOrCreateInstance)
|
- Bootstrap 5 modal conversion for snapshots view (data-bs-dismiss, modal-footer, getOrCreateInstance)
|
||||||
- ntfy default URL changed from ntfy.sh to ntfy.mokoconsulting.tech
|
- ntfy default URL changed from ntfy.sh to ntfy.mokoconsulting.tech
|
||||||
- Untranslated JFIELD_ORDERING_ASC / JFIELD_ORDERING_LABEL language keys replaced with component-specific keys
|
- Untranslated JFIELD_ORDERING_ASC / JFIELD_ORDERING_LABEL language keys replaced with component-specific keys
|
||||||
@@ -24,135 +31,9 @@
|
|||||||
- Profile dropdown IDs in backup records and dashboard show "#ID — Title (type)" format
|
- Profile dropdown IDs in backup records and dashboard show "#ID — Title (type)" format
|
||||||
- MokoRestore stalling: unhandled promise rejections from network errors or non-JSON responses left UI in loading state
|
- MokoRestore stalling: unhandled promise rejections from network errors or non-JSON responses left UI in loading state
|
||||||
|
|
||||||
## [01.43.00] --- 2026-06-24
|
|
||||||
|
|
||||||
|
|
||||||
## [01.43.00] --- 2026-06-24
|
## [01.43.00] --- 2026-06-24
|
||||||
|
|
||||||
## [01.42.00] --- 2026-06-23
|
## [01.42.00] --- 2026-06-23
|
||||||
|
|
||||||
|
|
||||||
## [01.42.00] --- 2026-06-23
|
## [01.42.00] --- 2026-06-23
|
||||||
|
|
||||||
## [01.41.00] — 2026-06-23
|
|
||||||
|
|
||||||
### Added — Multi-Remote Storage
|
|
||||||
- New `#__mokosuitebackup_remotes` table for multiple destinations per profile
|
|
||||||
- Remote destinations UI: AJAX-driven add/edit/delete/toggle modal on profile edit
|
|
||||||
- Engine uploads to ALL enabled destinations (BackupEngine + SteppedBackupEngine)
|
|
||||||
- Migration auto-converts existing SFTP/S3/GDrive/FTP profile columns to new table
|
|
||||||
- Backward compatibility: falls back to legacy single-remote columns if table empty
|
|
||||||
- Secrets masked in API responses, merged from DB on save
|
|
||||||
|
|
||||||
### Added — Content Snapshots
|
|
||||||
- Lightweight JSON snapshots of articles, categories, and modules
|
|
||||||
- Includes tags, custom fields, workflow associations, field values
|
|
||||||
- Restore modes: Replace (clean slate), Merge (upsert), Selective (per-article)
|
|
||||||
- Snapshot retention: max count + max age with automatic cleanup
|
|
||||||
- Scheduled snapshot task via com_scheduler
|
|
||||||
- CLI: `mokosuitebackup:snapshot create|restore|list|delete`
|
|
||||||
- REST API: create, list, restore, delete, download snapshots
|
|
||||||
- Tabbed browse modal: Articles / Categories / Modules with item counts
|
|
||||||
|
|
||||||
### Added — SFTP Remote Storage
|
|
||||||
- SFTP support with SSH key file authentication (key stored base64 in database)
|
|
||||||
- Auth type dropdown: Password / Key File / Key File + Passphrase
|
|
||||||
- SshKeyField: file upload via FileReader, key never exposed in HTML
|
|
||||||
- SFTP remote directory browser for path selection
|
|
||||||
- `__KEEP_EXISTING__` sentinel preserves key on profile re-save
|
|
||||||
|
|
||||||
### Added — MokoRestore Wizard (9 steps)
|
|
||||||
- Per-table conflict resolution: Replace / Skip / Merge / Data Only
|
|
||||||
- Preset buttons: "All Replace", "All Skip", "Everything except users"
|
|
||||||
- Post-restore actions: reset passwords, hits, versions, sessions, cache
|
|
||||||
- Auto-detect sanitized passwords and prompt for reset (random temp password)
|
|
||||||
- Standalone mode: restore.php scans directory for ZIP files
|
|
||||||
- Wrapped mode: restore.php bundled inside backup ZIP
|
|
||||||
- Security gate with filesystem verification + path traversal protection
|
|
||||||
|
|
||||||
### Added — Data Sanitization
|
|
||||||
- Sanitize user passwords: replace hashes with invalid sentinel
|
|
||||||
- Sanitize user emails: replace with dummy values
|
|
||||||
- Clear session data: exclude `#__session` table
|
|
||||||
- Preserve super admin credentials (optional)
|
|
||||||
- GDPR-friendly backup sharing for demos and staging sites
|
|
||||||
|
|
||||||
### Added — Backup Engine
|
|
||||||
- Pre-flight validation: directory, disk space, extensions, credentials, running backups
|
|
||||||
- Auto-verify archive integrity after creation (ZIP, tar.gz, 7z)
|
|
||||||
- 7z archive format via system 7za/7z CLI binary with native encryption
|
|
||||||
- Streaming database dump to temp file (prevents OOM on large sites)
|
|
||||||
- S3 streaming upload via CURLOPT_PUT (prevents OOM)
|
|
||||||
- Graceful remote degradation: local backup preserved if upload fails
|
|
||||||
- DatabaseDumper::dumpToFile() for memory-efficient operation
|
|
||||||
|
|
||||||
### Added — Admin UI
|
|
||||||
- Dashboard: snapshot widget, 30-day backup trend chart, per-profile storage breakdown
|
|
||||||
- CPanel admin dashboard module (mod_mokosuitebackup_cpanel) with quick actions
|
|
||||||
- Backup type filter dropdown in backups list
|
|
||||||
- Backup comparison: select two backups for side-by-side diff
|
|
||||||
- Archive browser: view files inside backup without extracting
|
|
||||||
- Manual purge: delete backups older than a date with count preview
|
|
||||||
- Backup count badges on profile list
|
|
||||||
- "Do not navigate away" warning in backup/restore progress modals
|
|
||||||
- Clickable placeholder pills for backup directory and archive name fields
|
|
||||||
- Comprehensive help modal with absolute/relative/placeholder path documentation
|
|
||||||
- Placeholder resolution display with EXAMPLE prefix
|
|
||||||
- All placeholders UPPERCASE: [HOST], [SITE_NAME], [DATE], [DATETIME], etc.
|
|
||||||
|
|
||||||
### Added — CLI & API
|
|
||||||
- `mokosuitebackup:restore` with --files-only, --db-only, --password options
|
|
||||||
- `mokosuitebackup:snapshot` with create, restore, list, delete actions
|
|
||||||
- REST API for snapshots: create, list, restore, delete, download
|
|
||||||
- Profile credentials masked in API responses
|
|
||||||
|
|
||||||
### Added — Notifications & Logging
|
|
||||||
- Email/ntfy notifications for site restore, snapshot create/restore
|
|
||||||
- Joomla Action Logs for restore, snapshot, and snapshot restore events
|
|
||||||
- Global ntfy server/topic/token settings (fallback for profiles)
|
|
||||||
|
|
||||||
### Added — Security & Configuration
|
|
||||||
- Webcron secret field with CSPRNG generator + strength meter
|
|
||||||
- IP whitelist field with current IP detection + one-click "Add my IP"
|
|
||||||
- 10 ACL permissions with full enforcement audit across all controllers
|
|
||||||
- Config defaults: archive format, MokoRestore mode, sanitization settings
|
|
||||||
- Path traversal protection on all archive extraction (ZIP, tar.gz, JPA)
|
|
||||||
|
|
||||||
### Fixed
|
|
||||||
- CLI RestoreCommand passed wrong arguments (filepath instead of record ID)
|
|
||||||
- JPA path traversal: reject `../` in archive entry paths
|
|
||||||
- S3Uploader OOM: streaming upload instead of file_get_contents
|
|
||||||
- DatabaseDumper OOM: streaming to file instead of in-memory string
|
|
||||||
- AkeebaImporter: removed unserialize() (PHP object injection risk)
|
|
||||||
- BackupTable: delete DB row before file (prevents data loss)
|
|
||||||
- RestoreEngine: staging path sanitized with preg_replace
|
|
||||||
- API profiles: sensitive fields masked with `***`
|
|
||||||
- Webcron: missing return after sendJsonResponse on auth failure
|
|
||||||
- loadFormData(): cast array to object (PHP 8.x TypeError fix)
|
|
||||||
- MokoRestore data-only mode: uses REPLACE INTO for existing rows
|
|
||||||
- Plaintext archive deleted on encryption failure
|
|
||||||
- TarGzArchiver: intermediate .tar cleaned in finally block
|
|
||||||
- Install script: single-line comments converted to block comments
|
|
||||||
- Orphaned root-level webservices plugin files removed
|
|
||||||
- include_mokorestore column: TINYINT changed to VARCHAR(20)
|
|
||||||
- Snapshot fields_values: scoped dump and restore to com_content.article (previously destroyed values for contacts, users, etc.)
|
|
||||||
- Run Backup button: accept CSRF token from GET (fixes "token did not match" on profile edit)
|
|
||||||
- SFTP fields: moved into remote fieldset for showon visibility; removed required attr that blocked non-SFTP saves
|
|
||||||
- Script.php merge conflict markers resolved
|
|
||||||
|
|
||||||
## [01.24.00] — 2026-06-02
|
|
||||||
|
|
||||||
### Added
|
|
||||||
- Initial release: full-site backup and restore for Joomla 6
|
|
||||||
- Database, files, and configuration backup
|
|
||||||
- ZIP and tar.gz archive formats with AES-256 encryption
|
|
||||||
- Differential backups based on file manifests
|
|
||||||
- FTP/FTPS, S3, Google Drive remote storage
|
|
||||||
- MokoRestore standalone restore wizard
|
|
||||||
- CLI backup and restore commands
|
|
||||||
- REST API for remote management
|
|
||||||
- Scheduled tasks via com_scheduler
|
|
||||||
- Email and ntfy push notifications
|
|
||||||
- Per-profile retention, exclusions, and notifications
|
|
||||||
- Akeeba Backup migration tool
|
|
||||||
- Admin dashboard with system health checks
|
|
||||||
|
|||||||
+1
-1
@@ -23,7 +23,7 @@ DEFGROUP: Template-Joomla
|
|||||||
INGROUP: Template-Joomla.Documentation
|
INGROUP: Template-Joomla.Documentation
|
||||||
REPO: https://git.mokoconsulting.tech/MokoConsulting/Template-Joomla
|
REPO: https://git.mokoconsulting.tech/MokoConsulting/Template-Joomla
|
||||||
PATH: /SECURITY.md
|
PATH: /SECURITY.md
|
||||||
VERSION: 01.45.07
|
VERSION: 01.45.00
|
||||||
BRIEF: Security vulnerability reporting and handling policy
|
BRIEF: Security vulnerability reporting and handling policy
|
||||||
-->
|
-->
|
||||||
|
|
||||||
|
|||||||
Submodule source/packages/MokoSuiteClient updated: 67e9cc6b38...9df6bea4b7
@@ -7,7 +7,7 @@
|
|||||||
-->
|
-->
|
||||||
<extension type="component" method="upgrade">
|
<extension type="component" method="upgrade">
|
||||||
<name>MokoSuiteBackup</name>
|
<name>MokoSuiteBackup</name>
|
||||||
<version>01.45.07</version>
|
<version>01.45.00</version>
|
||||||
<creationDate>2026-06-02</creationDate>
|
<creationDate>2026-06-02</creationDate>
|
||||||
<author>Moko Consulting</author>
|
<author>Moko Consulting</author>
|
||||||
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
||||||
|
|||||||
@@ -1 +0,0 @@
|
|||||||
/* 01.44.02 — no schema changes */
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
/* 01.44.03 — no schema changes */
|
|
||||||
@@ -0,0 +1 @@
|
|||||||
|
/* 01.45.00 — no schema changes */
|
||||||
@@ -1 +0,0 @@
|
|||||||
/* 01.45.02 — no schema changes */
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
/* 01.45.03 — no schema changes */
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
/* 01.45.05 — no schema changes */
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
/* 01.45.06 — no schema changes */
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
/* 01.45.07 — no schema changes */
|
|
||||||
@@ -394,8 +394,14 @@ class SteppedBackupEngine
|
|||||||
$restoreScriptName = MokoRestore::sanitizeScriptName($restoreScriptName);
|
$restoreScriptName = MokoRestore::sanitizeScriptName($restoreScriptName);
|
||||||
$restoreDir = dirname($session->archivePath);
|
$restoreDir = dirname($session->archivePath);
|
||||||
$session->restoreScriptPath = $restoreDir . '/' . $restoreScriptName;
|
$session->restoreScriptPath = $restoreDir . '/' . $restoreScriptName;
|
||||||
|
|
||||||
|
try {
|
||||||
MokoRestore::generateStandalone($session->restoreScriptPath);
|
MokoRestore::generateStandalone($session->restoreScriptPath);
|
||||||
$session->log('Standalone ' . $restoreScriptName . ' generated');
|
$session->log('Standalone ' . $restoreScriptName . ' generated');
|
||||||
|
} catch (\Throwable $e) {
|
||||||
|
$session->log('MokoRestore error: ' . $e->getMessage() . ' in ' . $e->getFile() . ':' . $e->getLine());
|
||||||
|
$session->log('Stack trace: ' . $e->getTraceAsString());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update record
|
// Update record
|
||||||
|
|||||||
@@ -8,7 +8,7 @@
|
|||||||
-->
|
-->
|
||||||
<extension type="module" client="administrator" method="upgrade">
|
<extension type="module" client="administrator" method="upgrade">
|
||||||
<name>mod_mokosuitebackup_cpanel</name>
|
<name>mod_mokosuitebackup_cpanel</name>
|
||||||
<version>01.45.07</version>
|
<version>01.45.00</version>
|
||||||
<creationDate>2026-06-23</creationDate>
|
<creationDate>2026-06-23</creationDate>
|
||||||
<author>Moko Consulting</author>
|
<author>Moko Consulting</author>
|
||||||
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
||||||
|
|||||||
@@ -7,7 +7,7 @@
|
|||||||
-->
|
-->
|
||||||
<extension type="plugin" group="actionlog" method="upgrade">
|
<extension type="plugin" group="actionlog" method="upgrade">
|
||||||
<name>Action Log - MokoSuiteBackup</name>
|
<name>Action Log - MokoSuiteBackup</name>
|
||||||
<version>01.45.07</version>
|
<version>01.45.00</version>
|
||||||
<creationDate>2026-06-04</creationDate>
|
<creationDate>2026-06-04</creationDate>
|
||||||
<author>Moko Consulting</author>
|
<author>Moko Consulting</author>
|
||||||
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
||||||
|
|||||||
@@ -7,7 +7,7 @@
|
|||||||
-->
|
-->
|
||||||
<extension type="plugin" group="console" method="upgrade">
|
<extension type="plugin" group="console" method="upgrade">
|
||||||
<name>Console - MokoSuiteBackup</name>
|
<name>Console - MokoSuiteBackup</name>
|
||||||
<version>01.45.07</version>
|
<version>01.45.00</version>
|
||||||
<creationDate>2026-06-04</creationDate>
|
<creationDate>2026-06-04</creationDate>
|
||||||
<author>Moko Consulting</author>
|
<author>Moko Consulting</author>
|
||||||
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
||||||
|
|||||||
@@ -7,7 +7,7 @@
|
|||||||
-->
|
-->
|
||||||
<extension type="plugin" group="content" method="upgrade">
|
<extension type="plugin" group="content" method="upgrade">
|
||||||
<name>Content - MokoSuiteBackup</name>
|
<name>Content - MokoSuiteBackup</name>
|
||||||
<version>01.45.07</version>
|
<version>01.45.00</version>
|
||||||
<creationDate>2026-06-04</creationDate>
|
<creationDate>2026-06-04</creationDate>
|
||||||
<author>Moko Consulting</author>
|
<author>Moko Consulting</author>
|
||||||
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<extension type="plugin" group="quickicon" method="upgrade">
|
<extension type="plugin" group="quickicon" method="upgrade">
|
||||||
<name>Quick Icon - MokoSuiteBackup</name>
|
<name>Quick Icon - MokoSuiteBackup</name>
|
||||||
<version>01.45.07</version>
|
<version>01.45.00</version>
|
||||||
<creationDate>2026-06-02</creationDate>
|
<creationDate>2026-06-02</creationDate>
|
||||||
<author>Moko Consulting</author>
|
<author>Moko Consulting</author>
|
||||||
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
||||||
|
|||||||
@@ -7,7 +7,7 @@
|
|||||||
-->
|
-->
|
||||||
<extension type="plugin" group="system" method="upgrade">
|
<extension type="plugin" group="system" method="upgrade">
|
||||||
<name>System - MokoSuiteBackup</name>
|
<name>System - MokoSuiteBackup</name>
|
||||||
<version>01.45.07</version>
|
<version>01.45.00</version>
|
||||||
<creationDate>2026-06-02</creationDate>
|
<creationDate>2026-06-02</creationDate>
|
||||||
<author>Moko Consulting</author>
|
<author>Moko Consulting</author>
|
||||||
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
||||||
|
|||||||
@@ -7,7 +7,7 @@
|
|||||||
-->
|
-->
|
||||||
<extension type="plugin" group="task" method="upgrade">
|
<extension type="plugin" group="task" method="upgrade">
|
||||||
<name>Task - MokoSuiteBackup</name>
|
<name>Task - MokoSuiteBackup</name>
|
||||||
<version>01.45.07</version>
|
<version>01.45.00</version>
|
||||||
<creationDate>2026-06-02</creationDate>
|
<creationDate>2026-06-02</creationDate>
|
||||||
<author>Moko Consulting</author>
|
<author>Moko Consulting</author>
|
||||||
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
||||||
|
|||||||
@@ -7,7 +7,7 @@
|
|||||||
-->
|
-->
|
||||||
<extension type="plugin" group="webservices" method="upgrade">
|
<extension type="plugin" group="webservices" method="upgrade">
|
||||||
<name>Web Services - MokoSuiteBackup</name>
|
<name>Web Services - MokoSuiteBackup</name>
|
||||||
<version>01.45.07</version>
|
<version>01.45.00</version>
|
||||||
<creationDate>2026-06-02</creationDate>
|
<creationDate>2026-06-02</creationDate>
|
||||||
<author>Moko Consulting</author>
|
<author>Moko Consulting</author>
|
||||||
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
||||||
|
|||||||
@@ -8,14 +8,14 @@
|
|||||||
<extension type="package" method="upgrade">
|
<extension type="package" method="upgrade">
|
||||||
<name>Package - MokoSuiteBackup</name>
|
<name>Package - MokoSuiteBackup</name>
|
||||||
<packagename>mokosuitebackup</packagename>
|
<packagename>mokosuitebackup</packagename>
|
||||||
<version>01.45.07</version>
|
<version>01.45.00</version>
|
||||||
<creationDate>2026-06-02</creationDate>
|
<creationDate>2026-06-02</creationDate>
|
||||||
<author>Moko Consulting</author>
|
<author>Moko Consulting</author>
|
||||||
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
<authorEmail>hello@mokoconsulting.tech</authorEmail>
|
||||||
<authorUrl>https://mokoconsulting.tech</authorUrl>
|
<authorUrl>https://mokoconsulting.tech</authorUrl>
|
||||||
<copyright>Copyright (C) 2026 Moko Consulting. All rights reserved.</copyright>
|
<copyright>Copyright (C) 2026 Moko Consulting. All rights reserved.</copyright>
|
||||||
<license>GPL-3.0-or-later</license>
|
<license>GPL-3.0-or-later</license>
|
||||||
<description>PKG_MOKOJOOMBCKUP_DESCRIPTION</description>
|
<description>PKG_MOKOJOOMBACKUP_DESCRIPTION</description>
|
||||||
|
|
||||||
<scriptfile>script.php</scriptfile>
|
<scriptfile>script.php</scriptfile>
|
||||||
|
|
||||||
@@ -29,6 +29,7 @@
|
|||||||
<file type="plugin" id="mokosuitebackup" group="content">plg_content_mokosuitebackup.zip</file>
|
<file type="plugin" id="mokosuitebackup" group="content">plg_content_mokosuitebackup.zip</file>
|
||||||
<file type="plugin" id="mokosuitebackup" group="actionlog">plg_actionlog_mokosuitebackup.zip</file>
|
<file type="plugin" id="mokosuitebackup" group="actionlog">plg_actionlog_mokosuitebackup.zip</file>
|
||||||
<file type="module" id="mod_mokosuitebackup_cpanel" client="administrator">mod_mokosuitebackup_cpanel.zip</file>
|
<file type="module" id="mod_mokosuitebackup_cpanel" client="administrator">mod_mokosuitebackup_cpanel.zip</file>
|
||||||
|
<file type="package" id="pkg_mokosuiteclient">MokoSuiteClient.zip</file>
|
||||||
</files>
|
</files>
|
||||||
|
|
||||||
<languages>
|
<languages>
|
||||||
@@ -36,7 +37,7 @@
|
|||||||
</languages>
|
</languages>
|
||||||
|
|
||||||
<updateservers>
|
<updateservers>
|
||||||
<server type="extension" name="MokoSuiteBackup Updates">https://git.mokoconsulting.tech/api/packages/MokoConsulting/generic/MokoSuiteBackup/latest/updates.xml</server>
|
<server type="extension" name="MokoSuiteBackup Updates">https://git.mokoconsulting.tech/MokoConsulting/MokoSuiteBackup/updates.xml</server>
|
||||||
</updateservers>
|
</updateservers>
|
||||||
<dlid prefix="dlid=" suffix=""/>
|
<dlid prefix="dlid=" suffix=""/>
|
||||||
<blockChildUninstall>true</blockChildUninstall>
|
<blockChildUninstall>true</blockChildUninstall>
|
||||||
|
|||||||
Reference in New Issue
Block a user