summaryrefslogtreecommitdiff
path: root/src/Script/Command
diff options
context:
space:
mode:
Diffstat (limited to 'src/Script/Command')
-rw-r--r--src/Script/Command/Site.php80
-rw-r--r--src/Script/Command/Site/Create.php99
2 files changed, 99 insertions, 80 deletions
diff --git a/src/Script/Command/Site.php b/src/Script/Command/Site.php
deleted file mode 100644
index 8a6a8e7..0000000
--- a/src/Script/Command/Site.php
+++ /dev/null
@@ -1,80 +0,0 @@
-<?php
-
-namespace App\Script\Command;
-
-use Symfony\Component\Console\Command\Command as SyCommand;
-use Symfony\Component\Console\Input\InputInterface;
-use Symfony\Component\Console\Output\OutputInterface;
-use Symfony\Component\Console\Input\InputArgument;
-use Symfony\Component\Console\Helper\ProgressBar;
-use App\Filesystem\CreateFile;
-use App\Filesystem\CreateDirectory;
-
-class Site extends SyCommand
-{
- protected function configure()
- {
- $this
- ->addArgument('name', InputArgument::REQUIRED, 'The name of the new site.');
-
- $this
- ->addArgument('domain', InputArgument::REQUIRED, 'The domain name of the new site.');
-
- $this
- ->setName('site:create')
- ->setDescription('Create a new site.')
- ->setHelp('This command allows you to create a new site.')
- ;
- }
-
- protected function execute(InputInterface $input, OutputInterface $output)
- {
- $taskCount = 6;
- $output->writeln(
- 'Creating new site with domain: '
- . $input->getArgument('domain')
- . ' and name: '
- . $input->getArgument('name')
- );
-
- $progressBar = new ProgressBar($output, $taskCount);
- $progressBar->setFormatDefinition('custom', ' %current%/%max% -- %message%');
- $progressBar->setFormat('custom');
- $progressBar->setMessage('Starting...');
- $progressBar->start();
- $progressBar->setMessage('Running pre-flight checks');
-
- $progressBar->advance();
- try {
- $create = new \App\Filesystem\CreateFile(DIPPER_ROOT . '/foo.test');
- $create = new \App\Filesystem\CreateDirectory(DIPPER_ROOT);
- sleep(1);
- } catch (\Exception $e) {
- $output->writeln('Error with pre-flight checks');
- $output->writeln($e->getMessage());
- exit;
- }
-
- $progressBar->advance();
- $progressBar->setMessage('Creating directory structure');
- sleep(1);
-
- $progressBar->advance();
- $progressBar->setMessage('Creating nginx config');
- sleep(1);
-
- $progressBar->advance();
- $progressBar->setMessage('Creating default index.php');
- sleep(1);
-
- $progressBar->advance();
- $progressBar->setMessage('Creating nginx config');
- sleep(1);
-
- $progressBar->advance();
- $progressBar->finish();
-
- $output->writeln('');
- $output->writeln('Complete');
- }
-}
diff --git a/src/Script/Command/Site/Create.php b/src/Script/Command/Site/Create.php
new file mode 100644
index 0000000..2526d2e
--- /dev/null
+++ b/src/Script/Command/Site/Create.php
@@ -0,0 +1,99 @@
+<?php
+
+namespace App\Script\Command;
+
+use Symfony\Component\Console\Command\Command as SyCommand;
+use Symfony\Component\Console\Input\InputInterface;
+use Symfony\Component\Console\Output\OutputInterface;
+use Symfony\Component\Console\Input\InputArgument;
+use Symfony\Component\Console\Helper\ProgressBar;
+use App\Filesystem\CreateFile;
+use App\Filesystem\CreateDirectory;
+
+/**
+ * A new Symfony command for creating a new site deployment
+ *
+ * @author Phil Burton <phil@d3r.com>
+ */
+class Create extends SyCommand
+{
+ /**
+ * Configure the command
+ *
+ * @author Phil Burton <phil@d3r.com>
+ */
+ protected function configure()
+ {
+ $this->addArgument('name', InputArgument::REQUIRED, 'The name of the new site.');
+ $this->addArgument('domain', InputArgument::REQUIRED, 'The domain name of the new site.');
+
+ $this
+ ->setName('site:create')
+ ->setDescription('Create a new site.')
+ ->setHelp('This command allows you to create a new site.');
+ }
+
+ /**
+ * Run the command
+ *
+ * @param InputInterface $input
+ * @param OutputInterface $output
+ * @author Phil Burton <phil@d3r.com>
+ */
+ protected function execute(InputInterface $input, OutputInterface $output)
+ {
+ $taskCount = 6;
+
+ $name = $input->getArgument('name');
+ $domain = $input->getArgument('domain');
+
+ $output->writeln(
+ 'Creating new site with domain: '
+ . $input->getArgument('domain')
+ . ' and name: '
+ . $input->getArgument('name')
+ );
+
+ // Set-up progress bar
+ $progressBar = new ProgressBar($output, $taskCount);
+ $progressBar->setFormatDefinition('custom', ' %current%/%max% -- %message%');
+ $progressBar->setFormat('custom');
+ $progressBar->setMessage('Starting...');
+ $progressBar->start();
+ $progressBar->setMessage('Running pre-flight checks');
+
+ // Construct the file commands so we run checks first
+ $progressBar->advance();
+
+ $tasks = [];
+
+ try {
+ $tasks['Creating site directory'] = new \App\Filesystem\CreateDirectory(SITES_ROOT . $name);
+ $tasks['Creating logs directory'] = new \App\Filesystem\CreateDirectory(SITES_ROOT . $name . '/logs');
+ $tasks['Creating access log file'] = new \App\Filesystem\CreateFile(SITES_ROOT . $name . '/logs/' . $name . '.access_log');
+ $tasks['Creating error log file'] = new \App\Filesystem\CreateFile(SITES_ROOT . $name . '/logs/' . $name . '.errors_log');
+ $tasks['Creating web folder'] = new \App\Filesystem\CreateDirectory(SITES_ROOT . $name . '/web');
+ $tasks['Creating directory index.php'] = new \App\Filesystem\CreateFile(SITES_ROOT . $name . '/web/index.php');
+ $tasks['Creating nginx config file'] = new \App\Filesystem\CreateFile(CONFIG_ROOT . $name . '.conf');
+ } catch (\Exception $e) {
+ $output->writeln('Error with pre-flight checks');
+ $output->writeln($e->getMessage());
+ exit;
+ }
+
+ foreach ($tasks as $message => $task) {
+ // Create file in web root for execution
+ $progressBar->advance();
+ $progressBar->setMessage($message);
+ $task->execute();
+ sleep(1);
+ }
+
+
+ // Finish up
+ $progressBar->advance();
+ $progressBar->finish();
+ $output->writeln('');
+ $output->writeln('Complete');
+ }
+}