ServerProfile.php 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. <?php
  2. /*
  3. * This file is part of the Predis package.
  4. *
  5. * (c) Daniele Alessandri <suppakilla@gmail.com>
  6. *
  7. * For the full copyright and license information, please view the LICENSE
  8. * file that was distributed with this source code.
  9. */
  10. namespace Predis\Profiles;
  11. use Predis\ClientException;
  12. use Predis\Commands\Processors\ICommandProcessor;
  13. use Predis\Commands\Processors\IProcessingSupport;
  14. /**
  15. * Base class that implements common functionalities of server profiles.
  16. *
  17. * @author Daniele Alessandri <suppakilla@gmail.com>
  18. */
  19. abstract class ServerProfile implements IServerProfile, IProcessingSupport
  20. {
  21. private static $_profiles;
  22. private $_registeredCommands;
  23. private $_processor;
  24. /**
  25. *
  26. */
  27. public function __construct()
  28. {
  29. $this->_registeredCommands = $this->getSupportedCommands();
  30. }
  31. /**
  32. * Returns a map of all the commands supported by the profile and their
  33. * actual PHP classes.
  34. *
  35. * @return array
  36. */
  37. protected abstract function getSupportedCommands();
  38. /**
  39. * Returns the default server profile.
  40. *
  41. * @return IServerProfile
  42. */
  43. public static function getDefault()
  44. {
  45. return self::get('default');
  46. }
  47. /**
  48. * Returns the development server profile.
  49. *
  50. * @return IServerProfile
  51. */
  52. public static function getDevelopment()
  53. {
  54. return self::get('dev');
  55. }
  56. /**
  57. * Returns a map of all the server profiles supported by default and their
  58. * actual PHP classes.
  59. *
  60. * @return array
  61. */
  62. private static function getDefaultProfiles()
  63. {
  64. return array(
  65. '1.2' => '\Predis\Profiles\ServerVersion12',
  66. '2.0' => '\Predis\Profiles\ServerVersion20',
  67. '2.2' => '\Predis\Profiles\ServerVersion22',
  68. '2.4' => '\Predis\Profiles\ServerVersion24',
  69. 'default' => '\Predis\Profiles\ServerVersion24',
  70. 'dev' => '\Predis\Profiles\ServerVersionNext',
  71. );
  72. }
  73. /**
  74. * Registers a new server profile.
  75. *
  76. * @param string $alias Profile version or alias.
  77. * @param string $profileClass FQN of a class implementing Predis\Profiles\IServerProfile.
  78. */
  79. public static function define($alias, $profileClass)
  80. {
  81. if (!isset(self::$_profiles)) {
  82. self::$_profiles = self::getDefaultProfiles();
  83. }
  84. $profileReflection = new \ReflectionClass($profileClass);
  85. if (!$profileReflection->isSubclassOf('\Predis\Profiles\IServerProfile')) {
  86. throw new ClientException(
  87. "Cannot register '$profileClass' as it is not a valid profile class"
  88. );
  89. }
  90. self::$_profiles[$alias] = $profileClass;
  91. }
  92. /**
  93. * Returns the specified server profile.
  94. *
  95. * @param string $version Profile version or alias.
  96. * @return IServerProfile
  97. */
  98. public static function get($version)
  99. {
  100. if (!isset(self::$_profiles)) {
  101. self::$_profiles = self::getDefaultProfiles();
  102. }
  103. if (!isset(self::$_profiles[$version])) {
  104. throw new ClientException("Unknown server profile: $version");
  105. }
  106. $profile = self::$_profiles[$version];
  107. return new $profile();
  108. }
  109. /**
  110. * {@inheritdoc}
  111. */
  112. public function supportsCommands(Array $commands)
  113. {
  114. foreach ($commands as $command) {
  115. if ($this->supportsCommand($command) === false) {
  116. return false;
  117. }
  118. }
  119. return true;
  120. }
  121. /**
  122. * {@inheritdoc}
  123. */
  124. public function supportsCommand($command)
  125. {
  126. return isset($this->_registeredCommands[strtolower($command)]);
  127. }
  128. /**
  129. * {@inheritdoc}
  130. */
  131. public function createCommand($method, $arguments = array())
  132. {
  133. $method = strtolower($method);
  134. if (!isset($this->_registeredCommands[$method])) {
  135. throw new ClientException("'$method' is not a registered Redis command");
  136. }
  137. $commandClass = $this->_registeredCommands[$method];
  138. $command = new $commandClass();
  139. $command->setArguments($arguments);
  140. if (isset($this->_processor)) {
  141. $this->_processor->process($command);
  142. }
  143. return $command;
  144. }
  145. /**
  146. * Defines new commands in the server profile.
  147. *
  148. * @param array $commands Named list of command IDs and their classes.
  149. */
  150. public function defineCommands(Array $commands)
  151. {
  152. foreach ($commands as $alias => $command) {
  153. $this->defineCommand($alias, $command);
  154. }
  155. }
  156. /**
  157. * Defines a new commands in the server profile.
  158. *
  159. * @param string $alias Command ID.
  160. * @param string $command FQN of a class implementing Predis\Commands\ICommand.
  161. */
  162. public function defineCommand($alias, $command)
  163. {
  164. $commandReflection = new \ReflectionClass($command);
  165. if (!$commandReflection->isSubclassOf('\Predis\Commands\ICommand')) {
  166. throw new ClientException("Cannot register '$command' as it is not a valid Redis command");
  167. }
  168. $this->_registeredCommands[strtolower($alias)] = $command;
  169. }
  170. /**
  171. * {@inheritdoc}
  172. */
  173. public function setProcessor(ICommandProcessor $processor)
  174. {
  175. if (!isset($processor)) {
  176. unset($this->_processor);
  177. return;
  178. }
  179. $this->_processor = $processor;
  180. }
  181. /**
  182. * {@inheritdoc}
  183. */
  184. public function getProcessor()
  185. {
  186. return $this->_processor;
  187. }
  188. /**
  189. * Returns the version of server profile as its string representation.
  190. *
  191. * @return string
  192. */
  193. public function __toString()
  194. {
  195. return $this->getVersion();
  196. }
  197. }