Silverstripe CMS can call Controllers through a command line interface (CLI) just as easily as through a web browser. This functionality can be used to automate tasks with cron jobs, run unit tests, or anything else that needs to interface over the command line.
The main entry point for any command line execution is cli-script.php
in the framework module.
For example, to run a database rebuild from the command line, use this command:
cd your-project-root/
php vendor/silverstripe/framework/cli-script.php dev/build
php -i
to find out
more). This can be a good thing, your CLI can be configured to use higher memory limits than you would want your website
to have.
Sake - Silverstripe CMS Make
Sake is a simple wrapper around cli-script.php
. It also tries to detect which php
executable to use if more than one
are available. It is accessible via vendor/bin/sake
.
Installation
sake
can be invoked using ./vendor/bin/sake
. For easier access, copy the sake
file into /usr/bin/sake
.
cd your-project-root/
sudo ./vendor/bin/sake installsake
Configuration
Sometimes Silverstripe CMS needs to know the URL of your site. For example, when sending an email or generating static files. When you're visiting the site in a web browser this is easy to work out, but when executing scripts on the command line, it has no way of knowing.
You can use the SS_BASE_URL
environment variable to specify this.
SS_BASE_URL="https://www.example.com/base-url"
Usage
sake
can run any controller by passing the relative URL to that controller.
sake /
# returns the homepage
sake dev/
# shows a list of development operations
sake
is particularly useful for running build tasks.
sake dev/build "flush=1"
It can also be handy if you have a long running script..
sake dev/tasks/MyReallyLongTask
Running processes
sake
can be used to make daemon processes for your application.
Make a task or controller class that runs a loop. To avoid memory leaks, you should make the PHP process exit when it hits some reasonable memory limit. Sake will automatically restart your process whenever it exits.
Include some appropriate sleep()
s so that your process doesn't hog the system. The best thing to do is to have a short
sleep when the process is in the middle of doing things, and a long sleep when doesn't have anything to do.
This code provides a good template:
use SilverStripe\Control\Controller;
class MyProcess extends Controller
{
private static $allowed_actions = [
'index'
];
function index()
{
set_time_limit(0);
while (memory_get_usage() < 32 * 1024 * 1024) {
if ($this->somethingToDo()) {
$this->doSomething();
sleep(1);
} else {
sleep(300);
}
}
}
}
Then the process can be managed through sake
sake -start MyProcess
sake -stop MyProcess
sake
stores pid
and log files in the project root directory.
Arguments
Parameters can be added to the command. All parameters will be available in $_GET
array on the server.
cd your-project-root/
php vendor/silverstripe/framework/cli-script.php myurl myparam=1 myotherparam=2
Or if you're using sake
vendor/bin/sake myurl "myparam=1&myotherparam=2"
Running Regular Tasks With Cron
On a UNIX machine, you can typically run a scheduled task with a cron job. Run
BuildTask
in Silverstripe CMS as a cron job using sake
.
The following will run MyTask
every minute.
* * * * * /your/site/folder/vendor/bin/sake dev/tasks/MyTask