summaryrefslogtreecommitdiffstats
path: root/source/Command/Channel/Add.php
diff options
context:
space:
mode:
authorPhilip Nicolcev <frugen@gmail.com>2014-08-24 13:12:44 -0400
committerPhilip Nicolcev <frugen@gmail.com>2014-08-24 13:12:44 -0400
commitf5fe739314de24e3a9cb94b9c8c64e11ed9cc14c (patch)
treebe46c6120d6dc0d08a7112a8dc80840281cbad33 /source/Command/Channel/Add.php
parent9ffeed7646620ae7de51b929a3b44f2cdffb677f (diff)
parent5d8755faf06fd2ff9d3977f103e641b0ba9f714e (diff)
downloadAJAX-Chat-origin/cli_testing.zip
AJAX-Chat-origin/cli_testing.tar.gz
AJAX-Chat-origin/cli_testing.tar.bz2
Merge pull request #178 from stevleibelt/masterorigin/cli_testing
Implemented Command Line Tools in cli_testing branch
Diffstat (limited to 'source/Command/Channel/Add.php')
-rw-r--r--source/Command/Channel/Add.php66
1 files changed, 66 insertions, 0 deletions
diff --git a/source/Command/Channel/Add.php b/source/Command/Channel/Add.php
new file mode 100644
index 0000000..751970c
--- /dev/null
+++ b/source/Command/Channel/Add.php
@@ -0,0 +1,66 @@
+<?php
+/**
+ * @author stev leibelt <artodeto@bazzline.net>
+ * @since 2014-08-14
+ */
+
+/**
+ * Class Command_Channel_Add
+ */
+class Command_Channel_Add extends Command_Channel_AbstractCommand
+{
+ /**
+ * @var string
+ */
+ private $inputName;
+
+ /**
+ * @throws Exception
+ */
+ public function execute()
+ {
+ end($this->channels);
+ $nextKey = (key($this->channels) + 1);
+ reset($this->channels);
+
+ $content = $this->file->read();
+
+ $content[] = '// added - ' . date('Y-m-d H:i:s');
+ $content[] = '$channels[' . $nextKey . '] = \'' . $this->inputName . '\';';
+
+ $this->file->write($content);
+ }
+
+ /**
+ * @return array
+ */
+ public function getUsage()
+ {
+ return array(
+ 'name="<name>"',
+ ' available channels: ' . implode(',', array_keys($this->channels)),
+ );
+ }
+
+ /**
+ * @throws Exception
+ */
+ public function verify()
+ {
+ if ($this->input->getNumberOfArguments() !== 1) {
+ throw new Exception(
+ 'invalid number of arguments provided'
+ );
+ }
+
+ $name = $this->input->getParameterValue('name');
+
+ if (is_null($name)) {
+ throw new Exception(
+ 'invalid name "' . $name . '" provided'
+ );
+ }
+
+ $this->inputName = $name;
+ }
+}