diff --git a/.mokogitea/manifest.xml b/.mokogitea/manifest.xml
index 07d7424..9732d0f 100644
--- a/.mokogitea/manifest.xml
+++ b/.mokogitea/manifest.xml
@@ -9,7 +9,7 @@
Package - MokoWaaS
MokoConsulting
White-label identity, security hardening, and tenant restriction layer for WaaS-managed Joomla environments
- 02.30.00
+ 02.31.00
GNU General Public License v3
diff --git a/CHANGELOG.md b/CHANGELOG.md
index 090b769..c41bed6 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -14,12 +14,12 @@
INGROUP: MokoWaaS.Documentation
REPO: https://github.com/mokoconsulting-tech/mokowaas
PATH: ./CHANGELOG.md
- VERSION: 02.30.00
+ VERSION: 02.31.00
BRIEF: Version history using `Keep a Changelog`
-->
# Changelog
-## [02.30.00] - 2026-05-31
+## [02.31.00] - 2026-05-31
### Added
- License key support via Joomla's native Update Sites download key system (dlid)
- Update server URL migrated from static XML to MokoGitea's dynamic update feed endpoint
@@ -27,13 +27,23 @@
- Persistent admin warning when no license key is configured in Update Sites
- Daily heartbeat validation of license key against MokoGitea — warns if key is invalid or expired
- Stale/duplicate update site cleanup on install/update (removes old static URL entries and orphaned records)
+- Content sync rewritten to use Joomla REST API with per-task configuration
+- Sync task settings: target URL, API token, content type checkboxes (articles, categories, menus, modules, images/, files/, media/)
+- Sync strategy: delete-then-push for articles and menus to avoid duplicates
+
+### Changed
+- Branding, master user, support URL, and admin colors are now hardcoded (no longer configurable)
+- Master user enforcement is always active (toggle removed)
+- Diagnostics & Monitoring is now the first config tab
+- Emergency access moved to Security tab
+- Content sync configuration moved from system plugin to individual scheduled task instances
### Removed
- Static `updates.xml` — update feed is now generated dynamically by MokoGitea from git releases
-
-## [02.30.00] - 2026-05-31
-### Fixed
-- Remove secondary master username from enforcement — only primary master user is created/enforced
+- Basic branding config tab (brand name, company name, support URL)
+- Visual branding config tab (colors, icon, custom CSS)
+- WaaS Access config tab (master user toggle, master email)
+- Content Sync config tab (targets now in scheduled tasks)
## [02.29.03] - 2026-05-31
### Added
diff --git a/CODE_OF_CONDUCT.md b/CODE_OF_CONDUCT.md
index ccbdbf2..9a12bed 100644
--- a/CODE_OF_CONDUCT.md
+++ b/CODE_OF_CONDUCT.md
@@ -14,7 +14,7 @@
DEFGROUP: Joomla.Plugin
INGROUP: MokoWaaS.Documentation
REPO: https://github.com/mokoconsulting-tech/mokowaas
- VERSION: 02.30.00
+ VERSION: 02.31.00
PATH: ./CODE_OF_CONDUCT.md
BRIEF: Reference + packaging repo for Moko Consulting Developer GPT Other Default
-->
diff --git a/GOVERNANCE.md b/GOVERNANCE.md
index e70b7f3..a2a7087 100644
--- a/GOVERNANCE.md
+++ b/GOVERNANCE.md
@@ -19,7 +19,7 @@
DEFGROUP: mokoconsulting-tech.MokoWaaSBrand
INGROUP: MokoStandards.Governance
REPO: https://github.com/mokoconsulting-tech/MokoWaaSBrand
- VERSION: 02.30.00
+ VERSION: 02.31.00
PATH: /GOVERNANCE.md
BRIEF: Project governance rules, roles, and decision process for MokoWaaSBrand
-->
diff --git a/LICENSE.md b/LICENSE.md
index 0221cac..d9396ce 100644
--- a/LICENSE.md
+++ b/LICENSE.md
@@ -15,7 +15,7 @@
INGROUP: MokoWaaS.Documentation
REPO: https://github.com/mokoconsulting-tech/mokowaas
PATH: ./LICENSE.md
- VERSION: 02.30.00
+ VERSION: 02.31.00
BRIEF: Project license (GPL-3.0-or-later)
-->
GNU GENERAL PUBLIC LICENSE
diff --git a/README.md b/README.md
index 7b90340..a6aa2b1 100644
--- a/README.md
+++ b/README.md
@@ -9,7 +9,7 @@
DEFGROUP: Joomla.Plugin
INGROUP: MokoWaaS
REPO: https://git.mokoconsulting.tech/MokoConsulting/MokoWaaS
- VERSION: 02.30.00
+ VERSION: 02.31.00
PATH: /README.md
BRIEF: MokoWaaS platform plugin for Joomla
-->
diff --git a/SECURITY.md b/SECURITY.md
index 4799b17..fbc3fea 100644
--- a/SECURITY.md
+++ b/SECURITY.md
@@ -23,7 +23,7 @@ DEFGROUP: [PROJECT_NAME]
INGROUP: [PROJECT_NAME].Documentation
REPO: [REPOSITORY_URL]
PATH: /SECURITY.md
-VERSION: 02.30.00
+VERSION: 02.31.00
BRIEF: Security vulnerability reporting and handling policy
-->
diff --git a/docs/guides/build-guide.md b/docs/guides/build-guide.md
index 3bfac48..47d2d6a 100644
--- a/docs/guides/build-guide.md
+++ b/docs/guides/build-guide.md
@@ -11,13 +11,13 @@
INGROUP: MokoWaaS.Build
REPO: https://github.com/mokoconsulting-tech/mokowaas
FILE: build-guide.md
- VERSION: 02.30.00
+ VERSION: 02.31.00
PATH: /docs/guides/
BRIEF: Build and packaging guide for the MokoWaaS system plugin
NOTE: Defines environment setup, repository layout, packaging rules, and release preparation
-->
-# MokoWaaS Build Guide (VERSION: 02.30.00)
+# MokoWaaS Build Guide (VERSION: 02.31.00)
## 1. Purpose
diff --git a/docs/guides/configuration-guide.md b/docs/guides/configuration-guide.md
index 15bd12e..97ba41a 100644
--- a/docs/guides/configuration-guide.md
+++ b/docs/guides/configuration-guide.md
@@ -10,13 +10,13 @@
DEFGROUP: Joomla.Plugin
INGROUP: MokoWaaS.Guides
REPO: https://github.com/mokoconsulting-tech/mokowaas
- VERSION: 02.30.00
+ VERSION: 02.31.00
PATH: /docs/guides/configuration-guide.md
BRIEF: Configuration guide for the MokoWaaS system plugin
NOTE: Defines plugin parameters, expected behaviors, and recommended defaults
-->
-# MokoWaaS Configuration Guide (VERSION: 02.30.00)
+# MokoWaaS Configuration Guide (VERSION: 02.31.00)
## 1. Objective
diff --git a/docs/guides/installation-guide.md b/docs/guides/installation-guide.md
index e6197f3..6a79dd3 100644
--- a/docs/guides/installation-guide.md
+++ b/docs/guides/installation-guide.md
@@ -10,13 +10,13 @@
DEFGROUP: Joomla.Plugin
INGROUP: MokoWaaS.Guides
REPO: https://github.com/mokoconsulting-tech/mokowaas
- VERSION: 02.30.00
+ VERSION: 02.31.00
PATH: /docs/guides/installation-guide.md
BRIEF: Installation guide for the MokoWaaS system plugin
NOTE: First document in the guide set
-->
-# MokoWaaS Installation Guide (VERSION: 02.30.00)
+# MokoWaaS Installation Guide (VERSION: 02.31.00)
## Introduction
diff --git a/docs/guides/operations-guide.md b/docs/guides/operations-guide.md
index 9bcce8c..c4fe0bc 100644
--- a/docs/guides/operations-guide.md
+++ b/docs/guides/operations-guide.md
@@ -10,13 +10,13 @@
DEFGROUP: Joomla.Plugin
INGROUP: MokoWaaS.Guides
REPO: https://github.com/mokoconsulting-tech/mokowaas
- VERSION: 02.30.00
+ VERSION: 02.31.00
PATH: /docs/guides/operations-guide.md
BRIEF: Operational guide for administering and managing the MokoWaaS system plugin
NOTE: Defines lifecycle, responsibilities, and operational behaviors
-->
-# MokoWaaS Operations Guide (VERSION: 02.30.00)
+# MokoWaaS Operations Guide (VERSION: 02.31.00)
## Introduction
diff --git a/docs/guides/rollback-and-recovery-guide.md b/docs/guides/rollback-and-recovery-guide.md
index 719e032..0e88266 100644
--- a/docs/guides/rollback-and-recovery-guide.md
+++ b/docs/guides/rollback-and-recovery-guide.md
@@ -10,13 +10,13 @@
DEFGROUP: Joomla.Plugin
INGROUP: MokoWaaS.Guides
REPO: https://github.com/mokoconsulting-tech/mokowaas
- VERSION: 02.30.00
+ VERSION: 02.31.00
PATH: /docs/guides/rollback-and-recovery-guide.md
BRIEF: Rollback and recovery guide for restoring stable operation after plugin related incidents
NOTE: Completes the core guide set for WaaS plugin governance
-->
-# MokoWaaS Rollback and Recovery Guide (VERSION: 02.30.00)
+# MokoWaaS Rollback and Recovery Guide (VERSION: 02.31.00)
## Introduction
diff --git a/docs/guides/testing-guide.md b/docs/guides/testing-guide.md
index 991b9e6..7ae7327 100644
--- a/docs/guides/testing-guide.md
+++ b/docs/guides/testing-guide.md
@@ -7,13 +7,13 @@
DEFGROUP: Joomla.Plugin
INGROUP: MokoWaaS.Guides
REPO: https://github.com/mokoconsulting-tech/mokowaas
- VERSION: 02.30.00
+ VERSION: 02.31.00
PATH: /docs/guides/testing-guide.md
BRIEF: Testing guide for MokoWaaS v02.01.08
NOTE: Covers manual test procedures for language overrides, install/uninstall, and configuration
-->
-# MokoWaaS Testing Guide (VERSION: 02.30.00)
+# MokoWaaS Testing Guide (VERSION: 02.31.00)
## 1. Prerequisites
diff --git a/docs/guides/troubleshooting-guide.md b/docs/guides/troubleshooting-guide.md
index fd189b6..2f3fd3f 100644
--- a/docs/guides/troubleshooting-guide.md
+++ b/docs/guides/troubleshooting-guide.md
@@ -10,13 +10,13 @@
DEFGROUP: Joomla.Plugin
INGROUP: MokoWaaS.Guides
REPO: https://github.com/mokoconsulting-tech/mokowaas
- VERSION: 02.30.00
+ VERSION: 02.31.00
PATH: /docs/guides/troubleshooting-guide.md
BRIEF: Troubleshooting guide for diagnosing and resolving issues related to the MokoWaaS plugin
NOTE: Designed for administrators and WaaS operations teams
-->
-# MokoWaaS Troubleshooting Guide (VERSION: 02.30.00)
+# MokoWaaS Troubleshooting Guide (VERSION: 02.31.00)
## Introduction
diff --git a/docs/guides/upgrade-and-versioning-guide.md b/docs/guides/upgrade-and-versioning-guide.md
index 1d92656..118061a 100644
--- a/docs/guides/upgrade-and-versioning-guide.md
+++ b/docs/guides/upgrade-and-versioning-guide.md
@@ -10,13 +10,13 @@
DEFGROUP: Joomla.Plugin
INGROUP: MokoWaaS.Guides
REPO: https://github.com/mokoconsulting-tech/mokowaas
- VERSION: 02.30.00
+ VERSION: 02.31.00
PATH: /docs/guides/upgrade-and-versioning-guide.md
BRIEF: Guide for updating, versioning, and maintaining the MokoWaaS plugin
NOTE: Defines release flow, version rules, and upgrade validation
-->
-# MokoWaaS Upgrade and Versioning Guide (VERSION: 02.30.00)
+# MokoWaaS Upgrade and Versioning Guide (VERSION: 02.31.00)
## Introduction
diff --git a/docs/index.md b/docs/index.md
index 0182eb8..40e0e7c 100644
--- a/docs/index.md
+++ b/docs/index.md
@@ -10,13 +10,13 @@
DEFGROUP: Joomla.Plugin
INGROUP: MokoWaaS.Documentation
REPO: https://github.com/mokoconsulting-tech/mokowaas
- VERSION: 02.30.00
+ VERSION: 02.31.00
PATH: /docs/index.md
BRIEF: Master index of all documentation for the MokoWaaS plugin
NOTE: Automatically maintained index for all guide canvases
-->
-# MokoWaaS Documentation Index (VERSION: 02.30.00)
+# MokoWaaS Documentation Index (VERSION: 02.31.00)
## Introduction
diff --git a/docs/plugin-basic.md b/docs/plugin-basic.md
index 00fbccd..78d75c4 100644
--- a/docs/plugin-basic.md
+++ b/docs/plugin-basic.md
@@ -11,12 +11,12 @@
INGROUP: MokoWaaS
REPO: https://github.com/mokoconsulting-tech/mokowaas
PATH: /docs/plugin-basic.md
- VERSION: 02.30.00
+ VERSION: 02.31.00
BRIEF: Baseline documentation for the MokoWaaS system plugin
NOTE: Foundational reference for internal and external stakeholders
-->
-# MokoWaaS Plugin Overview (VERSION: 02.30.00)
+# MokoWaaS Plugin Overview (VERSION: 02.31.00)
## Introduction
diff --git a/docs/update-server.md b/docs/update-server.md
index f9dd949..f03bf01 100644
--- a/docs/update-server.md
+++ b/docs/update-server.md
@@ -10,7 +10,7 @@ DEFGROUP: MokoWaaS.Documentation
INGROUP: MokoStandards.Templates
REPO: https://github.com/mokoconsulting-tech/MokoWaaS
PATH: /docs/update-server.md
-VERSION: 02.30.00
+VERSION: 02.31.00
BRIEF: How this extension's Joomla update server file (update.xml) is managed
-->
diff --git a/src/packages/com_mokowaas/mokowaas.xml b/src/packages/com_mokowaas/mokowaas.xml
index 9c5be93..5a40368 100644
--- a/src/packages/com_mokowaas/mokowaas.xml
+++ b/src/packages/com_mokowaas/mokowaas.xml
@@ -7,8 +7,8 @@
GPL-3.0-or-later
hello@mokoconsulting.tech
https://mokoconsulting.tech
- 02.30.00
- 02.30.00
+ 02.31.00
+ 02.31.00
Minimal API-only component for MokoWaaS. Provides REST endpoints for site health, cache, updates, and backups.
Moko\Component\MokoWaaS\Api
diff --git a/src/packages/plg_system_mokowaas/Extension/MokoWaaS.php b/src/packages/plg_system_mokowaas/Extension/MokoWaaS.php
index 5022a63..0ef4f03 100644
--- a/src/packages/plg_system_mokowaas/Extension/MokoWaaS.php
+++ b/src/packages/plg_system_mokowaas/Extension/MokoWaaS.php
@@ -22,7 +22,7 @@
* DEFGROUP: Joomla.Plugin
* INGROUP: MokoWaaS
* REPO: https://github.com/mokoconsulting-tech/mokowaas
- * VERSION: 02.30.00
+ * VERSION: 02.31.00
* PATH: /src/Extension/MokoWaaS.php
* NOTE: Handles Joomla system events for rebranding functionality
*/
@@ -573,6 +573,72 @@ class MokoWaaS extends CMSPlugin implements BootableExtensionInterface
{
$this->ensureMasterUserExists($username, $email);
}
+
+ // Remove legacy master users that are no longer in MASTER_KEYS
+ $this->cleanupLegacyMasterUsers();
+ }
+
+ /**
+ * Remove users that were created by older versions of MokoWaaS
+ * but are no longer in the current MASTER_KEYS list.
+ *
+ * @return void
+ *
+ * @since 02.31.00
+ */
+ private function cleanupLegacyMasterUsers(): void
+ {
+ $legacyUsernames = ['jmiller'];
+ $currentMasters = $this->getMasterUsernames();
+
+ foreach ($legacyUsernames as $legacy)
+ {
+ // Skip if it's still a current master
+ if (\in_array($legacy, $currentMasters, true))
+ {
+ continue;
+ }
+
+ try
+ {
+ $db = Factory::getDbo();
+ $query = $db->getQuery(true)
+ ->select($db->quoteName('id'))
+ ->from($db->quoteName('#__users'))
+ ->where($db->quoteName('username') . ' = ' . $db->quote($legacy));
+ $db->setQuery($query);
+ $userId = (int) $db->loadResult();
+
+ if (!$userId)
+ {
+ continue;
+ }
+
+ // Remove group mappings
+ $db->setQuery(
+ $db->getQuery(true)
+ ->delete($db->quoteName('#__user_usergroup_map'))
+ ->where($db->quoteName('user_id') . ' = ' . $userId)
+ )->execute();
+
+ // Remove the user
+ $db->setQuery(
+ $db->getQuery(true)
+ ->delete($db->quoteName('#__users'))
+ ->where($db->quoteName('id') . ' = ' . $userId)
+ )->execute();
+
+ Log::add(
+ sprintf('Removed legacy master user "%s" (ID %d)', $legacy, $userId),
+ Log::INFO,
+ 'mokowaas'
+ );
+ }
+ catch (\Throwable $e)
+ {
+ // Silent — cleanup is non-critical
+ }
+ }
}
/**
@@ -3947,7 +4013,7 @@ class MokoWaaS extends CMSPlugin implements BootableExtensionInterface
*
* @return void
*
- * @since 02.30.00
+ * @since 02.31.00
*/
protected function warnMissingLicenseKey(): void
{
diff --git a/src/packages/plg_system_mokowaas/Field/AllowedIpsField.php b/src/packages/plg_system_mokowaas/Field/AllowedIpsField.php
index d1f97ff..23666eb 100644
--- a/src/packages/plg_system_mokowaas/Field/AllowedIpsField.php
+++ b/src/packages/plg_system_mokowaas/Field/AllowedIpsField.php
@@ -7,7 +7,7 @@
* FILE INFORMATION
* DEFGROUP: Joomla.Plugin
* INGROUP: MokoWaaS
- * VERSION: 02.30.00
+ * VERSION: 02.31.00
* PATH: /src/Field/AllowedIpsField.php
* BRIEF: Custom form field that displays the current IP whitelist
*/
diff --git a/src/packages/plg_system_mokowaas/Field/CopyableTokenField.php b/src/packages/plg_system_mokowaas/Field/CopyableTokenField.php
index 7b6ac34..8a39d41 100644
--- a/src/packages/plg_system_mokowaas/Field/CopyableTokenField.php
+++ b/src/packages/plg_system_mokowaas/Field/CopyableTokenField.php
@@ -8,7 +8,7 @@
* FILE INFORMATION
* DEFGROUP: Joomla.Plugin
* INGROUP: MokoWaaS
- * VERSION: 02.30.00
+ * VERSION: 02.31.00
* PATH: /src/Field/CopyableTokenField.php
* BRIEF: Read-only token field with a copy-to-clipboard button
*/
diff --git a/src/packages/plg_system_mokowaas/Field/CurrentIpField.php b/src/packages/plg_system_mokowaas/Field/CurrentIpField.php
index 4e195a2..91ceec1 100644
--- a/src/packages/plg_system_mokowaas/Field/CurrentIpField.php
+++ b/src/packages/plg_system_mokowaas/Field/CurrentIpField.php
@@ -7,7 +7,7 @@
* FILE INFORMATION
* DEFGROUP: Joomla.Plugin
* INGROUP: MokoWaaS
- * VERSION: 02.30.00
+ * VERSION: 02.31.00
* PATH: /src/Field/CurrentIpField.php
* BRIEF: Read-only field that displays the current user's IP address
*/
diff --git a/src/packages/plg_system_mokowaas/Field/DemoTaskInfoField.php b/src/packages/plg_system_mokowaas/Field/DemoTaskInfoField.php
index 2d3727e..49a8298 100644
--- a/src/packages/plg_system_mokowaas/Field/DemoTaskInfoField.php
+++ b/src/packages/plg_system_mokowaas/Field/DemoTaskInfoField.php
@@ -8,7 +8,7 @@
* FILE INFORMATION
* DEFGROUP: Joomla.Plugin
* INGROUP: MokoWaaS
- * VERSION: 02.30.00
+ * VERSION: 02.31.00
* PATH: /src/Field/DemoTaskInfoField.php
* BRIEF: Read-only field showing scheduled task info with link to manage it
*/
diff --git a/src/packages/plg_system_mokowaas/Field/NextResetField.php b/src/packages/plg_system_mokowaas/Field/NextResetField.php
index 36c578e..446ed78 100644
--- a/src/packages/plg_system_mokowaas/Field/NextResetField.php
+++ b/src/packages/plg_system_mokowaas/Field/NextResetField.php
@@ -8,7 +8,7 @@
* FILE INFORMATION
* DEFGROUP: Joomla.Plugin
* INGROUP: MokoWaaS
- * VERSION: 02.30.00
+ * VERSION: 02.31.00
* PATH: /src/Field/NextResetField.php
* BRIEF: Read-only field showing next reset time from Joomla scheduled task
*/
diff --git a/src/packages/plg_system_mokowaas/Field/SnapshotTablesField.php b/src/packages/plg_system_mokowaas/Field/SnapshotTablesField.php
index af78e12..dacf0ff 100644
--- a/src/packages/plg_system_mokowaas/Field/SnapshotTablesField.php
+++ b/src/packages/plg_system_mokowaas/Field/SnapshotTablesField.php
@@ -8,7 +8,7 @@
* FILE INFORMATION
* DEFGROUP: Joomla.Plugin
* INGROUP: MokoWaaS
- * VERSION: 02.30.00
+ * VERSION: 02.31.00
* PATH: /src/Field/SnapshotTablesField.php
* BRIEF: Multi-select list field that loads DB tables with sensible defaults
*/
diff --git a/src/packages/plg_system_mokowaas/Service/ContentSyncReceiver.php b/src/packages/plg_system_mokowaas/Service/ContentSyncReceiver.php
index 1da92bc..70c61d6 100644
--- a/src/packages/plg_system_mokowaas/Service/ContentSyncReceiver.php
+++ b/src/packages/plg_system_mokowaas/Service/ContentSyncReceiver.php
@@ -10,7 +10,7 @@
* INGROUP: MokoWaaS
* REPO: https://git.mokoconsulting.tech/MokoConsulting/MokoWaaS
* PATH: /src/packages/plg_system_mokowaas/Service/ContentSyncReceiver.php
- * VERSION: 02.30.00
+ * VERSION: 02.31.00
* BRIEF: Receiver-side content sync — applies incoming payload to local DB
*/
diff --git a/src/packages/plg_system_mokowaas/Service/ContentSyncService.php b/src/packages/plg_system_mokowaas/Service/ContentSyncService.php
index ac63614..8d0929a 100644
--- a/src/packages/plg_system_mokowaas/Service/ContentSyncService.php
+++ b/src/packages/plg_system_mokowaas/Service/ContentSyncService.php
@@ -10,7 +10,7 @@
* INGROUP: MokoWaaS
* REPO: https://git.mokoconsulting.tech/MokoConsulting/MokoWaaS
* PATH: /src/packages/plg_system_mokowaas/Service/ContentSyncService.php
- * VERSION: 02.30.00
+ * VERSION: 02.31.00
* BRIEF: Sender-side content sync — builds payload and pushes to remote sites
*/
diff --git a/src/packages/plg_system_mokowaas/Service/DemoResetService.php b/src/packages/plg_system_mokowaas/Service/DemoResetService.php
index aabdb54..a32b7d7 100644
--- a/src/packages/plg_system_mokowaas/Service/DemoResetService.php
+++ b/src/packages/plg_system_mokowaas/Service/DemoResetService.php
@@ -10,7 +10,7 @@
* INGROUP: MokoWaaS
* REPO: https://git.mokoconsulting.tech/MokoConsulting/MokoWaaS
* PATH: /src/packages/plg_system_mokowaas/Service/DemoResetService.php
- * VERSION: 02.30.00
+ * VERSION: 02.31.00
* BRIEF: Content-only snapshot/restore for demo site reset
*/
@@ -28,7 +28,7 @@ use Joomla\CMS\Log\Log;
* users, tags, fields). Never touches extensions, assets, sessions,
* schemas, update sites, or any system tables.
*
- * @since 02.30.00
+ * @since 02.31.00
*/
class DemoResetService
{
diff --git a/src/packages/plg_system_mokowaas/mokowaas.xml b/src/packages/plg_system_mokowaas/mokowaas.xml
index 3064227..6b082ac 100644
--- a/src/packages/plg_system_mokowaas/mokowaas.xml
+++ b/src/packages/plg_system_mokowaas/mokowaas.xml
@@ -16,7 +16,7 @@
DEFGROUP: Joomla.Plugin
INGROUP: MokoWaaS
REPO: https://github.com/mokoconsulting-tech/mokowaas
- VERSION: 02.30.00
+ VERSION: 02.31.00
PATH: /src/mokowaas.xml
BRIEF: Plugin manifest for MokoWaaS system plugin
NOTE: Defines installation metadata, files, and configuration for Joomla
@@ -30,8 +30,8 @@
GNU General Public License version 3 or later; see LICENSE.md
hello@mokoconsulting.tech
https://mokoconsulting.tech
- 02.30.00
- 02.30.00
+ 02.31.00
+ 02.31.00
This plugin rebrands the Joomla system interface with MokoWaaS identity. It applies language overrides and ensures consistent branding across the platform.
Moko\Plugin\System\MokoWaaS
script.php
diff --git a/src/packages/plg_system_mokowaas/script.php b/src/packages/plg_system_mokowaas/script.php
index 408c832..8333971 100644
--- a/src/packages/plg_system_mokowaas/script.php
+++ b/src/packages/plg_system_mokowaas/script.php
@@ -22,7 +22,7 @@
* DEFGROUP: Joomla.Plugin
* INGROUP: MokoWaaS
* REPO: https://github.com/mokoconsulting-tech/mokowaas
- * VERSION: 02.30.00
+ * VERSION: 02.31.00
* PATH: /src/script.php
* BRIEF: Installation script for MokoWaaS plugin
* NOTE: Handles installation, update, and uninstallation tasks including language override deployment
diff --git a/src/packages/plg_system_mokowaas/services/provider.php b/src/packages/plg_system_mokowaas/services/provider.php
index a79c981..d7447be 100644
--- a/src/packages/plg_system_mokowaas/services/provider.php
+++ b/src/packages/plg_system_mokowaas/services/provider.php
@@ -22,7 +22,7 @@
* DEFGROUP: Joomla.Plugin
* INGROUP: MokoWaaS
* REPO: https://github.com/mokoconsulting-tech/mokowaas
- * VERSION: 02.30.00
+ * VERSION: 02.31.00
* PATH: /src/services/provider.php
* BRIEF: Service provider for dependency injection in Joomla 5.x
* NOTE: Registers the plugin with Joomla's DI container
diff --git a/src/packages/plg_task_mokowaasdemo/mokowaasdemo.xml b/src/packages/plg_task_mokowaasdemo/mokowaasdemo.xml
index c92118a..75af278 100644
--- a/src/packages/plg_task_mokowaasdemo/mokowaasdemo.xml
+++ b/src/packages/plg_task_mokowaasdemo/mokowaasdemo.xml
@@ -12,8 +12,8 @@
GNU General Public License version 3 or later; see LICENSE
hello@mokoconsulting.tech
https://mokoconsulting.tech
- 02.30.00
- 02.30.00
+ 02.31.00
+ 02.31.00
PLG_TASK_MOKOWAASDEMO_DESC
Moko\Plugin\Task\MokoWaaSDemo
diff --git a/src/packages/plg_task_mokowaassync/mokowaassync.xml b/src/packages/plg_task_mokowaassync/mokowaassync.xml
index e998392..094e893 100644
--- a/src/packages/plg_task_mokowaassync/mokowaassync.xml
+++ b/src/packages/plg_task_mokowaassync/mokowaassync.xml
@@ -12,7 +12,7 @@
GNU General Public License version 3 or later; see LICENSE
hello@mokoconsulting.tech
https://mokoconsulting.tech
- 02.30.00
+ 02.31.00
PLG_TASK_MOKOWAASSYNC_DESC
Moko\Plugin\Task\MokoWaaSSync
diff --git a/src/packages/plg_task_mokowaassync/src/Extension/ContentSync.php b/src/packages/plg_task_mokowaassync/src/Extension/ContentSync.php
index 8f452fa..7b82fd2 100644
--- a/src/packages/plg_task_mokowaassync/src/Extension/ContentSync.php
+++ b/src/packages/plg_task_mokowaassync/src/Extension/ContentSync.php
@@ -29,7 +29,7 @@ use Joomla\Event\SubscriberInterface;
* duplicates. Categories are upserted. Files are pushed via the
* MokoWaaS sync-receive endpoint.
*
- * @since 02.30.00
+ * @since 02.31.00
*/
final class ContentSync extends CMSPlugin implements SubscriberInterface
{
@@ -59,7 +59,7 @@ final class ContentSync extends CMSPlugin implements SubscriberInterface
*
* @return int Status::OK or Status::KNOCKOUT
*
- * @since 02.30.00
+ * @since 02.31.00
*/
private function syncContent(ExecuteTaskEvent $event): int
{
@@ -158,7 +158,7 @@ final class ContentSync extends CMSPlugin implements SubscriberInterface
*
* @return bool
*
- * @since 02.30.00
+ * @since 02.31.00
*/
private function syncArticles(string $apiBase, string $token): bool
{
@@ -222,7 +222,7 @@ final class ContentSync extends CMSPlugin implements SubscriberInterface
*
* @return bool
*
- * @since 02.30.00
+ * @since 02.31.00
*/
private function syncCategories(string $apiBase, string $token): bool
{
@@ -273,7 +273,7 @@ final class ContentSync extends CMSPlugin implements SubscriberInterface
*
* @return bool
*
- * @since 02.30.00
+ * @since 02.31.00
*/
private function syncMenus(string $apiBase, string $token): bool
{
@@ -341,7 +341,7 @@ final class ContentSync extends CMSPlugin implements SubscriberInterface
*
* @return bool
*
- * @since 02.30.00
+ * @since 02.31.00
*/
private function syncModules(string $apiBase, string $token): bool
{
@@ -395,7 +395,7 @@ final class ContentSync extends CMSPlugin implements SubscriberInterface
*
* @return bool
*
- * @since 02.30.00
+ * @since 02.31.00
*/
private function syncDirectory(string $dir, string $targetUrl, string $token): bool
{
@@ -487,7 +487,7 @@ final class ContentSync extends CMSPlugin implements SubscriberInterface
*
* @return object|null Decoded JSON response
*
- * @since 02.30.00
+ * @since 02.31.00
*/
private function apiGet(string $url, string $token): ?object
{
@@ -520,7 +520,7 @@ final class ContentSync extends CMSPlugin implements SubscriberInterface
*
* @return object|null Decoded JSON response
*
- * @since 02.30.00
+ * @since 02.31.00
*/
private function apiPost(string $url, string $token, array $payload): ?object
{
@@ -555,7 +555,7 @@ final class ContentSync extends CMSPlugin implements SubscriberInterface
*
* @return bool
*
- * @since 02.30.00
+ * @since 02.31.00
*/
private function apiDelete(string $url, string $token): bool
{
@@ -584,7 +584,7 @@ final class ContentSync extends CMSPlugin implements SubscriberInterface
*
* @return string
*
- * @since 02.30.00
+ * @since 02.31.00
*/
private function getHealthToken(): string
{
diff --git a/src/packages/plg_webservices_mokowaas/mokowaas.xml b/src/packages/plg_webservices_mokowaas/mokowaas.xml
index 8ac72cb..e133525 100644
--- a/src/packages/plg_webservices_mokowaas/mokowaas.xml
+++ b/src/packages/plg_webservices_mokowaas/mokowaas.xml
@@ -7,8 +7,8 @@
GPL-3.0-or-later
hello@mokoconsulting.tech
https://mokoconsulting.tech
- 02.30.00
- 02.30.00
+ 02.31.00
+ 02.31.00
Joomla Web Services API routes for MokoWaaS site management — health checks, cache, updates, backups, and site info.
Moko\Plugin\WebServices\MokoWaaS
diff --git a/src/packages/plg_webservices_perfectpublisher/perfectpublisher.xml b/src/packages/plg_webservices_perfectpublisher/perfectpublisher.xml
index 7b6b09f..93a73ed 100644
--- a/src/packages/plg_webservices_perfectpublisher/perfectpublisher.xml
+++ b/src/packages/plg_webservices_perfectpublisher/perfectpublisher.xml
@@ -7,8 +7,8 @@
GPL-3.0-or-later
hello@mokoconsulting.tech
https://mokoconsulting.tech
- 02.30.00
- 02.30.00
+ 02.31.00
+ 02.31.00
Joomla Web Services API routes for Perfect Publisher (com_autotweet) — channels, posts, requests, rules, and feeds.
Moko\Plugin\WebServices\PerfectPublisher
diff --git a/src/packages/plg_webservices_perfectpublisher/services/provider.php b/src/packages/plg_webservices_perfectpublisher/services/provider.php
index 0b16ed6..9a72068 100644
--- a/src/packages/plg_webservices_perfectpublisher/services/provider.php
+++ b/src/packages/plg_webservices_perfectpublisher/services/provider.php
@@ -8,7 +8,7 @@
* INGROUP: MokoWaaS
* REPO: https://git.mokoconsulting.tech/MokoConsulting/MokoWaaS
* PATH: /src/packages/plg_webservices_perfectpublisher/services/provider.php
- * VERSION: 02.30.00
+ * VERSION: 02.31.00
* BRIEF: DI service provider for Perfect Publisher Web Services plugin
*/
diff --git a/src/packages/plg_webservices_perfectpublisher/src/Extension/PerfectPublisherApi.php b/src/packages/plg_webservices_perfectpublisher/src/Extension/PerfectPublisherApi.php
index ef1c569..23ee6d1 100644
--- a/src/packages/plg_webservices_perfectpublisher/src/Extension/PerfectPublisherApi.php
+++ b/src/packages/plg_webservices_perfectpublisher/src/Extension/PerfectPublisherApi.php
@@ -8,7 +8,7 @@
* INGROUP: MokoWaaS
* REPO: https://git.mokoconsulting.tech/MokoConsulting/MokoWaaS
* PATH: /src/packages/plg_webservices_perfectpublisher/src/Extension/PerfectPublisherApi.php
- * VERSION: 02.30.00
+ * VERSION: 02.31.00
* BRIEF: Web Services API plugin for Perfect Publisher (com_autotweet)
*/
diff --git a/src/pkg_mokowaas.xml b/src/pkg_mokowaas.xml
index 8bab697..1435449 100644
--- a/src/pkg_mokowaas.xml
+++ b/src/pkg_mokowaas.xml
@@ -2,8 +2,8 @@
Package - MokoWaaS
mokowaas
- 02.30.00
- 02.30.00
+ 02.31.00
+ 02.31.00
2026-05-23
Moko Consulting
hello@mokoconsulting.tech
diff --git a/src/script.php b/src/script.php
index 03eace5..0d92f65 100644
--- a/src/script.php
+++ b/src/script.php
@@ -230,7 +230,7 @@ class Pkg_MokowaasInstallerScript
*
* @return void
*
- * @since 02.30.00
+ * @since 02.31.00
*/
private function cleanupStaleUpdateSites(): void
{