Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dereuromark/upgrade
Upgrade tools for CakePHP meant to facilitate migrating from one version of the framework to another
https://github.com/dereuromark/upgrade
Last synced: 2 months ago
JSON representation
Upgrade tools for CakePHP meant to facilitate migrating from one version of the framework to another
- Host: GitHub
- URL: https://github.com/dereuromark/upgrade
- Owner: dereuromark
- License: mit
- Fork: true (cakephp/upgrade)
- Created: 2014-12-27T00:51:13.000Z (about 10 years ago)
- Default Branch: master
- Last Pushed: 2024-10-15T22:27:41.000Z (3 months ago)
- Last Synced: 2024-10-17T07:39:30.196Z (3 months ago)
- Language: PHP
- Size: 635 KB
- Stars: 24
- Watchers: 5
- Forks: 5
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-cakephp - Upgrade app (extended) - An extended upgrade app for 3.x=>4.x and some 5.x snippets. (Migration)
README
# CakePHP Upgrade tool
[![CI](https://github.com/dereuromark/upgrade/actions/workflows/ci.yml/badge.svg)](https://github.com/dereuromark/upgrade/actions/workflows/ci.yml)
[![Minimum PHP Version](https://img.shields.io/badge/php-%3E%3D%208.1-8892BF.svg)](https://php.net/)
[![PHPStan](https://img.shields.io/badge/PHPStan-level%207-brightgreen.svg?style=flat)](https://phpstan.org/)
[![Software License](https://img.shields.io/badge/license-MIT-brightgreen.svg?style=flat-square)](LICENSE)Upgrade tool as standalone application for CakePHP meant to facilitate migrating
- ~~from CakePHP 2.x to 3.x.~~ [EOL]
- ~~supports the minor upgrades in 3.x - up until currently 3.8+.~~ [EOL]
- ~~supports basic stuff for 4.x~~ [See cake4 branch]
- supports basic stuff for 5.x + extension development possible**Warning** This tool is still under development and doesn't handle all aspects of migrating.
---
### CakePHP 5
The brand new upgrade command of this tool provides a configurable approach.
Define sets/levels and run it over your app or plugin:```
bin/cake upgrade files /path/to/repo -v -d
```
Keep verbose and dry-run for checking if it works as expected, then apply your changes for real.This tool works best in combination with the official [upgrade](https://github.com/cakephp/upgrade/) tool and its rector based approaches.
- dereuromark/upgrade handles basic cases and non-PHP files
- cakephp/upgrade handles PHP class files via rector (requires valid PHP files)If rector fails or cannot handle your app, you can try to use this tool completely by defining more regex
based rules for example.You can check active vs available tasks using `--help` together with `-v`.
It will list all available ones, active ones are in green.For docs on this check [here](docs/Upgrade.md).
---
## Installation
This plugin is standalone. Do not try to mix this with your existing app. Instead, put it somewhere completely separate from it.
Best to clone it (git clone ....).After downloading/cloning the upgrade tool, you need to install dependencies with `composer`
```bash
composer install
```Once dependencies are installed you can start using the `upgrade` shell.
Note: If you want to get the latest master, you can run `composer update` at your own risk.
It will download also all recent changes done.
Alternatively, you can lock it down to a stable version and then update.## IMPORTANT NOTICE
This tool is an add-on to original CakePHP upgrade tool and provides additional fixers:
- SkeletonThe FileUpgrade tool also:
- see `src/Task/?` (tons of custom fixes)Feel free to manually port those things back into the core one.
## Usage
### Upgrade command
Important upgrade steps:
- Skeleton upgrade (all skeleton files)```bash
bin/cake upgrade /home/mark/Sites/my-app
```### Upgrade files
See above `bin/cake upgrade files` docs.### Upgrade legacy shell
See cake4 branch.