diff --git a/scripts/export-wp.sh b/scripts/export-wp.sh index dc74d41..15f148b 100755 --- a/scripts/export-wp.sh +++ b/scripts/export-wp.sh @@ -1,75 +1,29 @@ #!/bin/sh -. ./config +echo "Exporting from $url .." -if [ "$1" = 'local' ] ; then - src_url="$local_url"; - dest_url="$remote_url"; - src_ssh="$local_ssh" - dest_ssh="$remote_ssh" -elif [ "$1" = 'remote' ] ; then - src_url="$remote_url"; - dest_url="$local_url"; - src_ssh="$remote_ssh" - dest_ssh="$local_ssh" -else - echo "error: must specify local or remote" - exit 5 -fi +_timestamp="$(date +%s)" +_db_filename="wordpress-$_timestamp.db" +_archive_filename="wordpress-$_timestamp.tar.gz" +_local_dest_dir="./data/$_target" -db_file="$wp_path/data.sql" -tar_file="/tmp/wordpress.tar.gz" - -############## source - -ssh -T $src_ssh << EOSSH +ssh -T $ssh << EOSSH +cd "$wp_path" wp db export \ --path="$wp_path" \ --dbuser="$wp_db_user" \ --dbpass="$wp_db_pass" \ --add-drop-table \ --allow-root \ - "$db_file" -tar czf "$tar_file" "$wp_path" + "/tmp/$_db_filename" +tar czf "/tmp/$_archive_filename" "$wp_path" EOSSH -scp "$src_ssh:$tar_file" "$tar_file" +scp "$ssh:/tmp/$_archive_filename" "$_local_dest_dir/$_archive_filename" +scp "$ssh:/tmp/$_db_filename" "$_local_dest_dir/$_db_filename" -ssh -T $src_ssh << EOSSH -rm "$db_file" -rm "$tar_file" +exit +ssh -T $ssh << EOSSH +rm "/tmp/$_db_filename" +rm "/tmp/$_archive_filename" EOSSH - -############## destination - -scp "$tar_file" "$dest_ssh:$tar_file" - -ssh -T $dest_ssh << EOSSH -rm -Rf "$wp_path" -cd / -tar xzf "$tar_file" - -wp db import \ - --path="$wp_path" \ - --dbuser="$wp_db_user" \ - --dbpass="$wp_db_pass" \ - --allow-root \ - "$db_file" -rm "$db_file" -rm "$tar_file" -wp search-replace \ - --path="$wp_path" \ - --allow-root \ - --skip-columns=guid \ - "$src_url" \ - "$dest_url" -wp option update home \ - --path="$wp_path" \ - --allow-root -wp option update home \ - --path="$wp_path" \ - --allow-root -EOSSH - - -mv "$tar_file" ./wordpress-"$(date +%s)".tar.gz