blazersix / satispress
Generate a Composer repository from installed WordPress plugins and themes.
Fund package maintenance!
paypal.me/bradyvercher
Installs: 163
Dependents: 0
Suggesters: 0
Security: 0
Stars: 508
Watchers: 15
Forks: 51
Open Issues: 22
Type:wordpress-plugin
Requires
- php: >=8.0
- cedaro/wp-plugin: ^0.5
- composer/installers: ^2.0
- composer/semver: ^3.2
- pimple/pimple: ^3.5
- psr/container: ^2.0
- psr/log: ^2.0
Requires (Dev)
- brain/monkey: ^2.2
- cedaro/wp-test-suite: dev-develop
- dealerdirect/phpcodesniffer-composer-installer: ^1.0
- phpcompatibility/phpcompatibility-wp: ^2
- phpunit/phpunit: ^8
- roave/security-advisories: dev-latest
- squizlabs/php_codesniffer: ^3.3
- wordpress/wordpress: ^6.6
- wp-cli/i18n-command: dev-main
- wp-coding-standards/wpcs: ^3
This package is auto-updated.
Last update: 2024-10-11 00:37:03 UTC
README
Facilitate modern best practices for managing WordPress websites by automating Composer support for private plugins and themes.
What is Composer?
When managing a WordPress site, multiple environments are usually needed for developing or testing code before deploying it to the live server. This requires being able to easily replicate the site and its dependencies between environments, which is where Composer comes in.
Composer allows for defining a project's dependencies, where they come from, how to access them, and then installing them from their source.
For WordPress sites, dependencies are usually plugins and themes, and even WordPress itself. Essentially, a single file (composer.json
) can be shared with another developer and they can rebuild the entire site structure from it.
Composer connects to repositories — directories that tell it where to find dependencies (packages) and how they should be handled.
Packagist is the main Composer repository for PHP packages and WordPress Packagist provides access to plugins and themes hosted in the directories on WordPress.org.
What's the problem?
Most commercial plugins and themes (also known as packages) aren't publicly available, so they can't be installed with Composer.
Some common workarounds include:
- Checking the plugin or theme in alongside custom project code in your version control system
- Creating a separate private repository for each plugin or theme and manually updating it as new versions are released
Neither option is ideal and can be a hassle to maintain over time.
Furthermore, access is usually restricted with proprietary licensing schemes that make it difficult to download releases programmatically.
How does SatisPress help?
SatisPress creates a dynamically updated Composer repository that provides access to private plugins and themes and makes new releases available automatically.
After installing SatisPress (it's a standard WordPress plugin):
- Choose the plugins and themes that you want to manage
- SatisPress zips the currently installed versions and stores them in a cache directory
- When an update for a managed plugin or theme becomes available, SatisPress downloads and saves it alongside previously cached releases
- A Composer repository is generated that can be included in your
composer.json
file to download any cached plugin or theme
There are several possible workflows, but SatisPress allows you to manage private plugins and themes in a standard WordPress installation, leveraging the built-in update process to handle the myriad licensing schemes that would be impossible to account for outside of WordPress.
It's the missing piece for managing WordPress websites with Composer.
What if I don't use Composer?
SatisPress can still benefit you since it makes releases downloadable directly from your admin panel, so you don't need to log in to vendors' sites to download updates.
Oftentimes vendors only provide access to the latest release, so you're stuck if something breaks and you didn't save the previous version. With SatisPress, you can download previously cached releases to rollback if needed and compare the code to see what changed.
Documentation
For installation notes, information about usage, security, and more, see the documentation.
Credits
Created by Brady Vercher and supported by Gary Jones.