In the previous post we covered:
- Creating an if/else statement.
- Getting arguments from command input.
- Getting the script to run from the command line.
- Writing an alias.
Part Two: Import a database from Pantheon* in one command.
This is a script to use when local is already set up and we want pull the latest database. After the script is installed you'll be able to download a backup from a particular environment on Pantheon and then import that backup into the existing database using a simple 3-word command:
$ dump mysite test
Even if you don't use Pantheon regularly, deconstructing this script can give you some ideas on how to build your own.
#!/usr/bin/env bash CY="\033[0;33m" #yellow CR="\033[0m" #reset CG="\033[0;32m" #green CB="\033[0;34m" #blue CO="\033[38;5;95m" #ochre if [ -z "$1" ] then printf "$CO • dump [site] [env] \n$CR" printf "$CY • Example: $CO dump mysite dev \n$CR" elif [ -z "$2" ] then printf "$CO • Enter the environment \n$CR" printf "$CO • dump [site] [env] \n$CR" printf "$CY • Example: $CO dump mysite dev \n$CR" else if [ ! -d "$HOME/Sites/dbs/$1" ] then mkdir $HOME/Sites/dbs/$1 fi drush @pantheon.$1.$2 sql-dump > $HOME/Sites/dbs/$1/$(date +%m%d\-%H)-$1-$2.sql cd $HOME/Sites/$1/sites/default drush sql-drop -y printf "$CY • My custom password hint. \n$CR" /Applications/MAMP/library/bin/mysql -u USERNAME -p $1 < $HOME/Sites/dbs/$1/$(date +%m%d\-%H)-$1-$2.sql drush rr printf "$CY • Script complete. \n$CR" fi
The first 5 lines set color values that we'll use in the prompts to increase readability.
if [ -z "$1" ]
If the prompt has no values, we want to give some sort of feedback to the user about what to enter.
if [ ! -d "$HOME/Sites/dbs/$1" ]
The script stores all backups in a specific directory. This line checks to see if that directory already exists.
This puts a human-readable date stamp on the dumped file.
Replace with your database's username. Use the appropriate security precautions.
Because this script creates a new database for each date, you may end up with a great deal of unwanted files. If you are dealing with large databases and not in the habit of regularly pruning files on your machine, you may want to remove the date stamp from the script.
drush sql-sync command is the more efficient and common way to get the latest database. Before this year, Pantheon did not support that command. Now that Pantheon is expanding its support for sql-sync, it is reasonable to imagine this script will be slowly phased out.
If you're having trouble with this script, you may want to revisit Practical Bash Scripts for Drupal Devs: Part I.