{"id":30756940,"url":"https://github.com/rtcamp/oneupdate","last_synced_at":"2026-05-19T10:03:37.619Z","repository":{"id":311145168,"uuid":"1033010875","full_name":"rtCamp/OneUpdate","owner":"rtCamp","description":"Manage your WordPress public and private plugins from central dashboard.","archived":false,"fork":false,"pushed_at":"2025-08-29T12:38:50.000Z","size":888,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"main","last_synced_at":"2025-08-29T13:35:50.831Z","etag":null,"topics":["onepress","wordpress","wordpress-development","wordpress-management","wordpress-plugin"],"latest_commit_sha":null,"homepage":"https://rtcamp.com","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"gpl-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/rtCamp.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":"docs/CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":"docs/CODE_OF_CONDUCT.md","threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":"docs/SECURITY.md","support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2025-08-06T07:01:48.000Z","updated_at":"2025-08-29T12:32:27.000Z","dependencies_parsed_at":"2025-08-22T22:31:21.962Z","dependency_job_id":null,"html_url":"https://github.com/rtCamp/OneUpdate","commit_stats":null,"previous_names":["rtcamp/oneupdate"],"tags_count":2,"template":false,"template_full_name":null,"purl":"pkg:github/rtCamp/OneUpdate","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/rtCamp%2FOneUpdate","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/rtCamp%2FOneUpdate/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/rtCamp%2FOneUpdate/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/rtCamp%2FOneUpdate/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/rtCamp","download_url":"https://codeload.github.com/rtCamp/OneUpdate/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/rtCamp%2FOneUpdate/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":273596260,"owners_count":25134259,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-09-04T02:00:08.968Z","response_time":61,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["onepress","wordpress","wordpress-development","wordpress-management","wordpress-plugin"],"created_at":"2025-09-04T10:50:49.658Z","updated_at":"2026-05-19T10:03:37.613Z","avatar_url":"https://github.com/rtCamp.png","language":"JavaScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"![Banner](./assets/src/images/banner.png)\n\n# OneUpdate \\- Efficient WordPress Plugin Management for Enterprise Brand Site Networks\n\n**Contributors:** [rtCamp](https://profiles.wordpress.org/rtcamp), [up1512001](https://github.com/up1512001), [danish17](https://github.com/danish17), [AnuragVasanwala](https://github.com/AnuragVasanwala), [aviral-mittal](https://github.com/aviral-mittal), [rishavjeet](https://github.com/rishavjeet), [vishal4669](https://github.com/vishal4669), [SushantKakade](https://github.com/SushantKakade)\n\n**Tags:** OnePress, WordPress, Plugin Manager, CI/CD, WordPress Automation, WordPress Plugins\n\nThis plugin is licensed under the GPL v2 or later.\n\n## Overview\n\nOneUpdate is a centralized plugin management solution designed for enterprises managing multiple WordPress sites through CI/CD workflows (like GitHub Actions). It streamlines plugin updates, installation, and management across multiple environments (development → staging → production) by automatically creating pull requests for all changes.\n\n## Description\n\n**OneUpdate** is a centralized plugin manager for WordPress. From a single governing site, you can:\n\n* **Install, update, and downgrade** plugins (with access to the latest 5 versions).  \n* **Activate, deactivate, and uninstall** plugins across multiple sites.  \n* Manage **public plugins** from WordPress.org and **private plugins** uploaded securely to your S3 instance.\n\nThis makes it easier to keep plugins consistent, secure, and up to date across all your WordPress environments.\n\n## Why OneUpdate?\n\nManaging plugin updates in a network of standalone sites in enterprise environments, where updates need to flow through multiple environments (develop → preprod → production), is a highly inefficient process. This can also lead to tech drift — brand sites diverging to such a level that managing them requires separate teams and effort.\n\nOneUpdate solves this by:\n\n- **Centralizing Management:** Single governing to manage plugins on all brand sites  \n- **Automating PR Creation:** Automatically creates pull requests for all environments  \n- **Maintaining Git History:** Uses single branch from base branch to prevent commit conflicts  \n- **Enterprise-Ready:** Built specifically for CI/CD-based WordPress deployments\n\n### Key Benefits\n\n- **Reduced effort:** Significantly reduce plugin management effort and time  \n- **Streamlined workflows:** Centralized management while maintaining site autonomy  \n- **Stack consolidation:** Helps brands converge on to a common stack of plugins, increasing compatibility and reusability  \n- **Cost reduction:** Ultimately, reduced efforts and reduced time \\= cost reduction\n\n## Features\n\n### Core Functionality\n\n- **Intuitive Plugin Browser:** Admin interface with advanced search and filtering options  \n- **Real-time Status Monitoring:** Up-to-date information about plugin version and status  \n- **Scalable Architecture:** Handles both public (available on [WordPress.org](https://wordpress.org/plugins/)) and private plugins  \n- **Dual Architecture Support:** Works with WordPress multisite and standalone installations  \n- **Secure API Integration:** REST API with unique authentication keys for safe operations\n\n### Plugin Management Actions\n\n- **Bulk Operations:** Update all plugins across multiple sites simultaneously  \n- **Version Control:** Install specific versions from the latest 5 available releases  \n- **Site-Specific Actions:** Activate, deactivate, install, or uninstall on selected sites  \n- **Private Plugin Support:** Upload and manage proprietary plugins  \n- **Automated PR Creation:** Generate pull requests for all changes across environments\n\n## System Requirements\n\n| Prerequisites | CI/CD managed sites (GitHub/GitLab/Bitbucket) |\n\n## Installation \u0026 Setup\n\nFor detailed installation instructions, system requirements, and step-by-step configuration guides, please see our comprehensive [**Installation and Setup Guide**](./docs/INSTALLATION.md).\n\n## Usage Guide\n\n### Accessing the governing\n\nNavigate to **OneUpdate → Plugin Manager** in your WordPress admin to access the centralized management interface.\n\n### Plugin Management Actions\n\n#### Plugin Activation/Deactivation\n\n- Click the **3 dot menu** next to any plugin  \n- Select **\"Activate on sites\"** or **\"Deactivate on sites\"**  \n- Choose target sites and confirm\n\n#### Version Management\n\n- Select **\"Change version/update\"** from the plugin menu  \n- Choose from the latest 5 available versions  \n- Select target sites for the update\n\n#### Plugin Removal\n\n- Select **\"Uninstall from sites\"** from the plugin menu  \n- Choose sites for plugin removal  \n- Confirm the action\n\n#### Installing New Plugins\n\n**Public Plugins:**\n\n1. Click **\"Add Plugin\"** button  \n2. Select **\"Public Plugin\"**  \n3. Search any WordPress.org plugin  \n4. Choose version and target sites\n\n**Private Plugins:**\n\n1. Click **\"Add Plugin\"** → **\"Private Plugin\"**  \n2. Upload plugin ZIP file  \n3. Select installation sites  \n4. Note: Uploaded files expire after 1 hour\n\n#### Bulk Operations\n\n- Use **\"Update All\"** to update all available plugins  \n- Applies only to WordPress.org plugins with available updates\n\n### Filtering and Search\n\n- **Filter by Status:** Active, inactive, or update available  \n- **Filter by Site:** View plugins for specific sites  \n- **Filter by Type:** Public or private plugins  \n- **Search:** Search by plugin name and description\n\n## Development \u0026 Contributing\n\nOneUpdate is actively developed and maintained by [rtCamp](https://rtcamp.com/).\n\n- **Repository:** [github.com/rtCamp/OneUpdate](https://github.com/rtCamp/OneUpdate)  \n- **Contributing Guide:** [docs/CONTRIBUTING.md](./docs/CONTRIBUTING.md)  \n- **Development Guide:** [docs/DEVELOPMENT.md](./docs/DEVELOPMENT.md)\n\nWe welcome contributions\\! Please read our contributing guidelines before submitting pull requests.\n\n### Workflow Overview\n\n1. **Setup Phase:** Install OneUpdate on governing site and all brand sites, then register brand sites with the governing site  \n2. **Plugin Management:** Administrator manages plugins through the governing site dashboard  \n3. **Source Integration:** Plugins are sourced from WordPress.org (public) or S3 (private)  \n4. **Automation:** GitHub Actions workflows automatically create pull requests across all environments  \n5. **Deployment:** Changes flow through your CI/CD pipeline (dev → staging → production)\n\n## Frequently Asked Questions\n\n### How are plugins managed?\n\nPlugins are managed using a combination of GitHub Actions and WordPress REST APIs with comprehensive security checks.\n\n### Can I install plugins directly from GitHub?\n\nYes, plugins installed directly via GitHub will be tracked on the governing site, even if not added through OneUpdate.\n\n### Are there limits on plugin management?\n\nThere are no hard limits on the number of plugins you can manage from the governing site.\n\n### Can I remove plugins from specific sites?\n\nYes, you can remove plugins from specific sites directly through the dashboard.\n\n### How long do private plugins remain available?\n\nPrivate plugin uploads expire after 1 hour for security purposes. You'll need to re-upload if you want to use them after expiration.\n\n## Troubleshooting\n\n### Plugin Not Showing on the governing site\n\n- Verify governing site configuration  \n- Check network connectivity between sites  \n- Confirm REST API permissions\n\n### Search Not Working\n\n- Search functionality covers plugin names and descriptions only  \n- Author names and other properties are not searchable\n\n### Pull Requests Not Created\n\n- Ensure GitHub workflows are properly configured:  \n  - `oneupdate-pr-creation.yml`  \n  - `oneupdate-pr-creation-private.yml`  \n- Verify GitHub PAT token permissions  \n- Check repository access rights\n\n### Common Issues\n\n- **API Connection Failures:** Verify authentication keys and network connectivity  \n- **S3 Upload Errors:** Check S3 credentials and bucket permissions  \n- **Workflow Failures:** Review GitHub Actions logs for specific error details\n\n## Support \u0026 Community\n\n- **Issues \u0026 Bug Reports:** [GitHub Issues](https://github.com/rtCamp/OneUpdate/issues)  \n- **Feature Requests:** [GitHub Discussions](https://github.com/rtCamp/OneUpdate/discussions)  \n- **Documentation:** [Project Wiki](https://github.com/rtCamp/OneUpdate/wiki)\n\n## License\n\nThis project is licensed under the GPL v2 or later \\- see the [LICENSE](http://LICENSE) file for details.\n\n---\n\n**Made with ❤️ by [rtCamp](https://rtcamp.com/)**  \n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Frtcamp%2Foneupdate","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Frtcamp%2Foneupdate","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Frtcamp%2Foneupdate/lists"}