Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ItinerisLtd/composify
Turn WordPress plugin zip files into git repositories, so that composer version constraints work properly.
https://github.com/ItinerisLtd/composify
cli composer composify wordpress wordpress-development
Last synced: about 2 months ago
JSON representation
Turn WordPress plugin zip files into git repositories, so that composer version constraints work properly.
- Host: GitHub
- URL: https://github.com/ItinerisLtd/composify
- Owner: ItinerisLtd
- License: mit
- Created: 2018-12-18T10:13:36.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2024-11-04T17:52:53.000Z (2 months ago)
- Last Synced: 2024-11-11T10:22:51.155Z (2 months ago)
- Topics: cli, composer, composify, wordpress, wordpress-development
- Language: TypeScript
- Homepage:
- Size: 1.95 MB
- Stars: 48
- Watchers: 10
- Forks: 3
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# composify
Turn WordPress plugin zip files into git repositories, so that composer version constraints work properly.
[![oclif](https://img.shields.io/badge/cli-oclif-brightgreen.svg)](https://oclif.io)
[![Version](https://img.shields.io/npm/v/@itinerisltd/composify.svg)](https://npmjs.org/package/@itinerisltd/composify)
[![Downloads/week](https://img.shields.io/npm/dw/@itinerisltd/composify.svg)](https://npmjs.org/package/@itinerisltd/composify)
[![License](https://img.shields.io/npm/l/@itinerisltd/composify.svg)](https://github.com/ItinerisLtd/composify/blob/master/package.json)
[![Hire Itineris](https://img.shields.io/badge/Hire-Itineris-ff69b4.svg)](https://www.itineris.co.uk/contact/)- [Goal](#goal)
- [Requirements](#requirements)
- [Installation](#installation)
- [Usage](#usage)
- [Examples](#examples)
- [Gravity Forms](#gravity-forms)
- [Advanced Custom Fields Pro](#advanced-custom-fields-pro)
- [Kinsta MU Plugins](#kinsta-mu-plugins)
- [FAQ](#faq)
- [How to install the `composify`-ed plugin via `composer`?](#how-to-install-the-composify-ed-plugin-via-composer)
- [How to `composify` plugin zip URLs which are *password-protected*?](#how-to-composify-plugin-zip-urls-which-are-password-protected)
- [Can I change default flag values via environment variables?](#can-i-change-default-flag-values-via-environment-variables)
- [Can I install `composify` instead of using `$ npx`?](#can-i-install-composify-instead-of-using--npx)
- [How about plugins on wordpress.org?](#how-about-plugins-on-wordpressorg)
- [What to do when `fatal: Could not read from remote repository`?](#what-to-do-when-fatal-could-not-read-from-remote-repository)
- [Is it a must to use `composify` with Bedrock?](#is-it-a-must-to-use-composify-with-bedrock)
- [Any Alternatives?](#any-alternatives)
- [It looks awesome. Where can I find some more goodies like this?](#it-looks-awesome-where-can-i-find-some-more-goodies-like-this)
- [This isn't on wp.org. Where can I give a ⭐️⭐️⭐️⭐️⭐️ review?](#this-isnt-on-wporg-where-can-i-give-a-%EF%B8%8F%EF%B8%8F%EF%B8%8F%EF%B8%8F%EF%B8%8F-review)
- [Feedback](#feedback)
- [Security](#security)
- [Change log](#change-log)
- [Credits](#credits)
- [License](#license)## Goal
Since plugin authors do not usually provide custom composer repositories (e.g: [Private Packagist](https://packagist.com/), [satis](https://getcomposer.org/doc/articles/handling-private-packages-with-satis.md#satis)), installing premium WordPress plugins via `composer` is not easy.
[Lots](https://kinsta.com/blog/bedrock-trellis/) [of](https://gist.github.com/beaverbuilder/8ab6fd1f054582a1fe5ae053c3b75a55/e7ce9dd744255778583705b6da6cdce53a295506#file-composer-bb-theme-config-json) [tutorials](https://deliciousbrains.com/using-composer-manage-wordpress-themes-plugins/) teach you: open `composer.json` and add the following within the `repositories` array:
```json
// https://kinsta.com/blog/bedrock-trellis/
{
"type": "package",
"package": {
"name": "kinsta/kinsta-mu-plugins",
"type": "wordpress-muplugin",
"version": "2.0.15",
"dist": {
"url": "https://kinsta.com/kinsta-tools/kinsta-mu-plugins.zip",
"type": "zip"
}
}
}
```The problems:
- if `package.dist.url` is *version-locked*, the `repositories` array has to be updated whenever a new plugin version is released
- if `package.dist.url` is not *version-locked*,`$ composer install` is not deterministic (even with `composer.lock`)
* `package.dist.url` always points to the latest version
* `package.version` becomes meaningless because the downloaded zip could be a newer version
* running `$ composer install` (without changing anything) could break the site because a newer plugin version is installed
* when composer caching invoked, there is no way to know which plugin version will be installedThe solution / what `composify` does:
1. download the plugin zip file
2. unzip it
3. generate `composer.json`
4. commit plugins files and `composer.json`
5. `$ git tag`
5. `$ git push --follow-tags`## Requirements
- NodeJS v10.0.0 or later
## Installation
`$ npx @itinerisltd/composify` just works! No installation required.
## Usage
```sh-session
$ npx @itinerisltd/composify --help
Turn WordPress plugin zip files into git repositories, so that composer version constraints work properlyUSAGE
$ composifyOPTIONS
-b, --branch=branch
the default branch of your remote repository [example: main]-d, --directory=directory
directory name after unzip [example: kinsta-mu-plugins]-f, --file=file
main plugin file which containing the plugin header comment [example:
kinsta-mu-plugins.php]-h, --help
show CLI help-n, --name=name
(required) package name [example: kinsta-mu-plugins]-o, --vendor=vendor
(required) vendor / organization name [example: itinerisltd]-r, --repo=repo
remote url or local path to the gti repository [example:
https://github.com/ItinerisLtd/kinsta-mu-plugins.git]-t, --type=wordpress-plugin|wordpress-muplugin|wordpress-theme
(required) [default: wordpress-plugin] package type-u, --[no-]unzip-subdir
unzip file into a sub-directory, only use when default options are breaking-v, --version
show CLI version-z, --zip=zip
(required) remote url or local path to the latest zip file [example:
https://kinsta.com/kinsta-tools/kinsta-mu-plugins.zip OR
/User/me/kinsta-mu-plugins.zip]
```## Examples
### Gravity Forms
```sh-session
$ npx @itinerisltd/composify --vendor=itinerisltd --name=gravityforms --zip=
```Note the flags:
```sh-session
$ wget
$ tree .
.
└── gravityforms_x.y.z.zip$ unzip -o ./gravityforms_2.4.5.zip
$ tree .
.
├── gravityforms <-- `--directory`
│ ├── gravityforms.php <-- `--file`
│ ├── xxx
│ └── yyy.php
└── gravityforms_x.y.z.zip
```* `--directory` is omitted because it defaults to `${name}`, i.e: `gravityforms`
* `--file` is omitted because it defaults to `${name}.php`, i.e: `gravityforms.php`
* `--repo` is omitted because it defaults to `https://github.com/${vendor}/${name}.git`
* `--unzipDir` is omitted because main plugin file is inside `--directory`### Advanced Custom Fields Pro
```sh-session
$ npx @itinerisltd/composify --vendor=itinerisltd --name=advanced-custom-fields-pro --file=acf.php --zip=https://connect.advancedcustomfields.com/xxx
```Note the flags:
```sh-session
$ wget https://connect.advancedcustomfields.com/xxx
$ tree .
.
└── advanced-custom-fields-pro.zip$ unzip -o ./advanced-custom-fields-pro.zip
$ tree .
.
├── advanced-custom-fields-pro <-- `--directory`
│ ├── acf.php <-- `--file`
│ ├── readme.txt
│ └── xxx
└── advanced-custom-fields-pro.zip
```* `--file` is set to `acf.php`
### Kinsta MU Plugins
```sh-session
$ npx @itinerisltd/composify --vendor=itinerisltd --name=kinsta-mu-plugins --zip=https://kinsta.com/kinsta-tools/kinsta-mu-plugins.zip --unzip-subdir --type=wordpress-muplugin
```Note the flags:
```sh-session
$ wget https://kinsta.com/kinsta-tools/kinsta-mu-plugins.zip
$ tree .
.
└── kinsta-mu-plugins.zip
$ unzip -o ./kinsta-mu-plugins.zip
$ tree .
.
├── kinsta-mu-plugins
│ ├── xxx
│ └── yyy
├── kinsta-mu-plugins.php <-- `--file`
└── kinsta-mu-plugins.zip
```* `--unzip-subdir` is set because the unzipped content is not *contained* inside a `--directory`
## FAQ
### How to install the `composify`-ed plugin via `composer`?
Open `composer.json` and add your git remote into `repositories`:
```json
{
"repositories": [
{
"type": "git",
"url": "https://github.com//"
}
]
}
``````sh-session
$ composer require /
```See: https://getcomposer.org/doc/05-repositories.md#vcs
### How to `composify` plugin zip URLs which are *password-protected*?
1. Download the zip files to your computer first
2. `$ composify/bin/run -z /path/to/the-plugin.zip -o itinerisltd -n the-plugin`Note: This is a v0.3 feature.
### Can I change default flag values via environment variables?
Yes.
These 2 commands are equivalent:
```sh-session
$ COMPOSIFY_VENDOR=itinerisltd COMPOSIFY_NAME=gravityforms COMPOSIFY_ZIP= npx @itinerisltd/composify
$ npx @itinerisltd/composify --vendor=itinerisltd --name=gravityforms --zip=
```### Can I install `composify` instead of using `$ npx`?
Yes. However, you are responsible for updating it.
```sh-session
# yarn or npm doesn't matter
$ yarn global add @itinerisltd/composify
$ composify --vendor=itinerisltd --name=gravityforms --zip=
```### How about plugins on wordpress.org?
Use [WordPress Packagist](https://wpackagist.org/) instead.
### What to do when `fatal: Could not read from remote repository`?
```sh-session
ERROR: Repository not found.
fatal: Could not read from remote repository.
```Make sure you have:
- created a git repository on remote server
- [chosen remote url correctly](https://help.github.com/en/articles/which-remote-url-should-i-use)
- [configure git authentication correctly](https://stackoverflow.com/questions/17659206/git-push-results-in-authentication-failed) on your computer or CI server
- granted both read and write accesses to the remote repository for the git user on your computer or CI server### Is it a must to use `composify` with Bedrock?
No.
Although we prefer and sponsor [Bedrock](https://github.com/roots/bedrock/#bedrock-sponsors) at [Itineris](https://www.itineris.co.uk/), you can `composify` any plugin zip files into git repositories, and install them via [composer](https://getcomposer.org/doc/05-repositories.md#vcs).
Bedrock alternatives:
- [Composer in WordPress](https://composer.rarst.net/)
- [WP Starter](https://wecodemore.github.io/wpstarter/)### Any Alternatives?
- [Release Belt](https://github.com/Rarst/release-belt) - Composer repo for ZIPs
- [Private Packagist Vendor](https://packagist.com/vendors) - Use JSON to make any ZIP file available through Composer.### It looks awesome. Where can I find some more goodies like this?
- Articles on [Itineris' blog](https://www.itineris.co.uk/blog/)
- More projects on [Itineris' GitHub profile](https://github.com/itinerisltd)
- Follow [@itineris_ltd](https://twitter.com/itineris_ltd) and [@TangRufus](https://twitter.com/tangrufus) on Twitter
- Hire [Itineris](https://www.itineris.co.uk/services/) to build your next awesome site### This isn't on wp.org. Where can I give a ⭐️⭐️⭐️⭐️⭐️ review?
Thanks! Glad you like it. It's important to make my boss know somebody is using this project. Instead of giving reviews on wp.org, consider:
- tweet something good with mentioning [@itineris_ltd](https://twitter.com/itineris_ltd) and [@TangRufus](https://twitter.com/tangrufus)
- star this [Github repo](https://github.com/ItinerisLtd/composify)
- watch this [Github repo](https://github.com/ItinerisLtd/composify)
- write blog posts
- submit pull requests
- [hire Itineris](https://www.itineris.co.uk/services/)## Feedback
**Please provide feedback!** We want to make this library useful in as many projects as possible.
Please submit an [issue](https://github.com/ItinerisLtd/composify/issues/new) and point out what you do and don't like, or fork the project and make suggestions.
**No issue is too small.**## Security
If you discover any security related issues, please email [[email protected]](mailto:[email protected]) instead of using the issue tracker.
## Change log
Please see [CHANGELOG](./CHANGELOG.md) for more information on what has changed recently.
## Credits
[composify](https://github.com/ItinerisLtd/composify) is a [Itineris Limited](https://www.itineris.co.uk/) project created by [Tang Rufus](https://typist.tech).
Full list of contributors can be found [here](https://github.com/ItinerisLtd/composify/graphs/contributors).
## License
[composify](https://github.com/ItinerisLtd/composify) is released under the [MIT License](https://opensource.org/licenses/MIT).