This is a simple script package for deploying PHP projects to a shared hosting server via
FTP or FTPS. It allows you to synchronize directories or upload individual files using lftp and curl.
Name: Donatas Glodenis
Email: dg@lapas.info
This project has the following dependencies:
- bash: Used to run the deployment script itself;
- lftp: Used for synchronizing directories;
- curl: Used for uploading individual files;
- composer: Required for installing this package and updating the vendor directory before and after deployment.
Note: The project has been tested on Ubuntu 24.04 LTS.
Ensure that bash, lftp, curl, and composer are installed and accessible in your system's PATH.
You can install this package via Composer by running these commands at the root of your project:
composer require dgvirtual/deploy-via-ftp:dev-masterNote: although the project will not be used on the production server, it should be installed
using composer require and not require-dev, as the app removes all dev-only packages before
deploying vendor directory, and it should not remove itself.
This will install the deploy-via-ftp package from your GitHub repository and make the
deployment script available in your project.
Then you will be able to run the deploy script via command:
./vendor/dgvirtual/deploy-via-ftp/src/deploy.sh [options]You can also add an entry to your project's composer.json scripts section:
"scripts": {
"deploy": "./vendor/dgvirtual/deploy-via-ftp/src/deploy.sh"
}to be able to run the script more conveniently as
composer deploy [options]You can use the following commands to synchronize directories with your remote FTP server:
composer deploy app
composer deploy vendor
composer deploy public
composer deploy public dry-runYou can also combine multiple directories in a single command:
composer deploy app vendor- app: Synchronize the
appdirectory only. - vendor: Synchronize the
vendordirectory only. - public: Synchronize the
public_htmldirectory only. - dry-run: Perform dry run (without changing content on the server).
To upload a single file, use the following command:
composer deploy onefile [local_path]Example:
composer deploy onefile app/Controllers/Test.phpThis will upload app/Controllers/Test.php to the corresponding location on your FTP server.
The remote path will be determined based on the local path.
Before you can use the deployment script, you need to configure your FTP settings.
- On the first run, if the
.ftp_configfile is missing in the main project directory, the script will prompt you to create it by running aninstall.shscript. - The
install.shscript will:- Copy
ftp-config.exampleto.ftp_config. - Optionally add
.ftp_configto your.gitignorefile. - Instruct you to edit
.ftp_configwith your FTP credentials.
- Copy
# .ftp_config
USERNAME="myname"
PASSWORD="mySecretPass"
PROTOCOL="ftps" # or "ftp"
PORT=21
SERVER="ftp.example.com"
# Remote directories
REMOTE_APP="/myproject/app"
REMOTE_VENDOR="/myproject/vendor"
REMOTE_PUBLIC_HTML="/public_html"
# Exclusion patterns
APP_EXCLUDE_GLOBS=""
VENDOR_EXCLUDE_GLOBS=""
PUBLIC_EXCLUDE_GLOBS="--exclude-glob='uploads/*' --exclude-glob='index.php'"
# Local directories
LOCAL_APP="app"
LOCAL_VENDOR="vendor"
LOCAL_PUBLIC_HTML="public"Edit this file with your FTP credentials and paths as needed.
- The script assumes that your project follows a structure where directories like
app,vendor, andpublic_htmlare located in the base directory, while the server you deploy to placesappandvendorinsidemyprojectdirectory, which, along withpublic_html, is at the root of the directory structure accessible to ftp. - Make sure to review the exclusion patterns in the
.ftp_configfile and adjust them to suit your project.
If you have any issues or need further assistance, feel free to contact the author at dg@lapas.info.
This README.md file provides clear instructions for installing, configuring, and using the deploy-via-ftp script, tailored specifically for your needs.