Deploy tasks for Robo Task Runner
$auth = new \DigipolisGent\Robo\Task\Deploy\Ssh\Auth\KeyFile('user', '/home/myuser/.ssh/id_dsa');
$result = $this->taskPushPackage('192.168.1.1', $auth)
->port(8022)
->timeout(15)
->destinationFolder('/folder/on/server')
->package('/path/to/local/package.tar.gz')
->run();
$auth = new \DigipolisGent\Robo\Task\Deploy\Ssh\Auth\KeyFile('user', '/home/myuser/.ssh/id_dsa');
$result = $this->taskSFTP('192.168.1.1', $auth)
->port(8022)
->timeout(15)
// Download file from server.
->get('/path/to/remote/file.txt', '/path/to/local/file.txt')
// Upload file to server.
->put('/path/to/remote/file.txt', '/path/to/local/file.txt')
->run();
$auth = new \DigipolisGent\Robo\Task\Deploy\Ssh\Auth\KeyFile('user', '/home/myuser/.ssh/id_dsa');
$result = $this->taskSsh('192.168.1.1', $auth)
->port(8022)
->timeout(15)
// Set the remote directory to execute the commands in.
->remoteDirectory('/path/to/remote/dir')
->exec('composer install')
->run();
$result = $this
->taskSymlinkFolderFileContents('/path/to/source', '/path/to/destination')
->run();
As this command will most likely be used to symlink config files on a server during deployment, this task should be used in a command that runs on the server. For example:
RoboFile.php on the server (let's say 192.168.1.1 in folder /path/to/remote/dir):
<?php
class RoboFile extends \Robo\Tasks
{
use \DigipolisGent\Robo\Task\Deploy\loadTasks;
/**
* Creates the symlinks.
*/
public function symlinks($source, $dest)
{
$this
->taskSymlinkFolderFileContents($source, $dest)
->run();
}
}
RoboFile.php on the build server / your local machine:
<?php
class RoboFile extends \Robo\Tasks
{
use \DigipolisGent\Robo\Task\Deploy\loadTasks;
/**
* Creates the symlinks.
*/
public function symlinks($source, $dest)
{
$auth = new \DigipolisGent\Robo\Task\Deploy\Ssh\Auth\KeyFile('user', '/home/myuser/.ssh/id_dsa');
$this->taskSsh('192.168.1.1', $auth)
->port(8022)
->timeout(15)
->remoteDirectory('/path/to/remote/dir')
->exec('vendor/bin/robo symlink ' . $source . ' ' . $dest)
->run();
}
}
$filesystemConfig = [
'local' => [
'type' => 'Local',
'root' => '/home/myuser/backups',
],
];
$dbConfig = [
'development' => [
'type' => 'mysql',
'host' => 'localhost',
'port' => '3306',
'user' => 'root',
'pass' => 'password',
'database' => 'test',
'singleTransaction' => true,
'ignoreTables' => [],
],
'production' => [
'type' => 'mysql',
'host' => 'localhost',
'port' => '3306',
'user' => 'root',
'pass' => 'password',
'database' => 'test',
'ignoreTables' => [],
'structureTables' => [],
'tables' => [],
'dataOnly' => false,
'orderedDump' => false,
'singleTransaction' => true,
'extra' => '--opt',
],
];
// Store a backup of the development database in /home/myuser/backups/dev.sql.tar.gz.
$result = $this->taskDatabaseBackup($filesystemConfig, $dbConfig)
->database('development')
->destination('dev.sql')
->compression('tar')
->run();
$filesystemConfig = [
'local' => [
'type' => 'Local',
'root' => '/home/myuser/backups',
],
];
$dbConfig = [
'development' => [
'type' => 'mysql',
'host' => 'localhost',
'port' => '3306',
'user' => 'root',
'pass' => 'password',
'database' => 'test',
'singleTransaction' => true,
'ignoreTables' => [],
],
'production' => [
'type' => 'mysql',
'host' => 'localhost',
'port' => '3306',
'user' => 'root',
'pass' => 'password',
'database' => 'test',
'ignoreTables' => [],
'structureTables' => [],
'tables' => [],
'dataOnly' => false,
'orderedDump' => false,
'singleTransaction' => true,
'extra' => '--opt',
],
];
// Restore a backup of the development database located at /home/myuser/backups/dev.sql.tar.gz.
$result = $this->taskDatabaseRestore($filesystemConfig, $dbConfig)
->database('development')
->source('dev.sql.tar.gz')
->compression('tar')
->run();
More information on the configuration options for the file systems can be found at https://github.com/backup-manager/backup-manager.
More information on the configuration options for the databases can be found at https://github.com/backup-manager/backup-manager. However, we provide our own MySql database handler. The configuration options are explained below:
$dbConfig = [
'production' => [
// Specify it's a mysql database.
'type' => 'mysql',
// Specify the database credentials.
'host' => 'localhost',
'port' => '3306',
'user' => 'root',
'pass' => 'password',
'database' => 'test',
// Tables to exclude from the export. This option will be ignored if the
// 'tables' configuration option is set, because all tables will be
// excluded except the ones specified in the 'tables' option. Therefore,
// adding a table to the 'ignoreTables' would be the same as omitting it
// from tbe 'tables' option if that option has a non-empty) value.
'ignoreTables' => [],
// Tables to only export the table structure for. A good example would
// be a cache table, since most of the time you wouldn't want this
// table's data in a backup. The structure of the tables specified here
// will be exported even if the 'tables' configuration options has a
// (non-empty) value and these tables are not in it.
'structureTables' => [],
// Tables to export. Leave empty to export all tables (except those
// specified in the 'ignoreTables' configuration option).
'tables' => [],
// Export only data, not table structure.
'dataOnly' => false,
// Order by primary key and add line breaks for efficient diff in
// revision control. Slows down the dump.
'orderedDump' => false,
// If singleTransaction is set to true, the --single-transcation flag
// will be set. This is useful on transactional databases like InnoDB.
// http://dev.mysql.com/doc/refman/5.7/en/mysqldump.html#option_mysqldump_single-transaction
'singleTransaction' => true,
// Extra options to pass to mysqldump (e.g. '--opt --quick').
'extra' => '--opt',
],
];
This package provides default commands wich you can use in your RoboFile.php
like so:
class RoboFile extends \Robo\Tasks
{
use \DigipolisGent\Robo\Task\Deploy\Commands\loadCommands;
}
vendor/bin/robo digipolis:database-backup [DATABASE] [OPTIONS]
Implement an on-event hook for the digipolis-db-config event to return the datbase config as specified above used by this command. For example:
/**
* @hook on-event digipolis-db-config
*/
public function defaultDbConfig()
{
$dbConfig = [];
$dbConfig['default'] = [
'type' => 'mysql',
'host' => 'localhost',
'port' => '3306',
'user' => 'root',
'pass' => '$up3r$3cr3tP@$$w0rD',
'database' => 'my_database',
'structureTables' => [],
'extra' => '--skip-add-locks --no-tablespaces',
];
return $dbConfig;
}
The database config key. See above for more details. In de given example, this argument would have to be 'production'. Defaults to 'default'.
Path to a PHP file containing filesystem config as documented at https://github.com/backup-manager/backup-manager. Defaults to the root directory of the local filesystem.
Path to a PHP file containing database config as documented at
https://github.com/backup-manager/backup-manager. Defaults to a database with
the name of the current working directory as database name, on localhost
port
3306
, user root
and an empty password.
The compression to use for this backup. Defaults to tar
.
The destination file for this backup. Defaults to project.tar.gz
in the
current working directory.
The destination type (e.g. local
, dropbox
, ftp
). Defaults to local
.
vendor/bin/robo digipolis:database-restore [DATABASE] [OPTIONS]
Implement an on-event hook for the digipolis-db-config event to return the datbase config as specified above used by this command. For example:
/**
* @hook on-event digipolis-db-config
*/
public function defaultDbConfig()
{
$dbConfig = [];
$dbConfig['default'] = [
'type' => 'mysql',
'host' => 'localhost',
'port' => '3306',
'user' => 'root',
'pass' => '$up3r$3cr3tP@$$w0rD',
'database' => 'my_database',
'structureTables' => [],
'extra' => '--skip-add-locks --no-tablespaces',
];
return $dbConfig;
}
The database config key. See above for more details. In de given example, this argument would have to be 'production'. Defaults to 'default'.
Path to a PHP file containing filesystem config as documented at https://github.com/backup-manager/backup-manager. Defaults to the root directory of the local filesystem.
Path to a PHP file containing database config as documented at
https://github.com/backup-manager/backup-manager. Defaults to a database with
the name of the current working directory as database name, on localhost
port
3306
, user root
and an empty password.
The compression of the given backup. Defaults to tar
.
The source file to restore. Defaults to project.tar.gz
in the current working
directory.
The source type (e.g. local
, dropbox
, ftp
). Defaults to local
.
vendor/bin/robo digipolis:push-package USER HOST PACKAGE [DESTINATION] [OPTIONS]
The user to connect to the host.
The host to connect to.
The package (tar-file) to push.
The destination folder on the server. Defaults to the home directory of the user.
The password to connect to the host.
The private key file to connect to the host.
The port to connect on. Defaults to 22
.
The timeout for the connection in seconds. Defaults to 10
.