diff options
author | Philip Nicolcev <frugen@gmail.com> | 2014-08-24 13:12:44 -0400 |
---|---|---|
committer | Philip Nicolcev <frugen@gmail.com> | 2014-08-24 13:12:44 -0400 |
commit | f5fe739314de24e3a9cb94b9c8c64e11ed9cc14c (patch) | |
tree | be46c6120d6dc0d08a7112a8dc80840281cbad33 /source/Command/Channel/Add.php | |
parent | 9ffeed7646620ae7de51b929a3b44f2cdffb677f (diff) | |
parent | 5d8755faf06fd2ff9d3977f103e641b0ba9f714e (diff) | |
download | AJAX-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.php | 66 |
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; + } +} |