123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163 |
- <?php
- /**
- * Text_CAPTCHA - creates a CAPTCHA for Turing tests.
- * Base class file for using Text_CAPTCHA.
- *
- * PHP version 5
- *
- * @category Text
- * @package Text_CAPTCHA
- * @author Christian Wenz <wenz@php.net>
- * @license http://www.opensource.org/licenses/bsd-license.php BSD License
- * @link http://pear.php.net/package/Text_CAPTCHA
- */
- /**
- * Require Exception class for error handling.
- */
- require_once 'Text/CAPTCHA/Exception.php';
- /**
- * Require Text_Password class for generating the phrase.
- */
- require_once 'Text/Password.php';
- /**
- * Text_CAPTCHA - creates a CAPTCHA for Turing tests.
- * Class to create a Turing test for websites by creating an image, ASCII art or
- * something else with some (obfuscated) characters.
- *
- * @category Text
- * @package Text_CAPTCHA
- * @author Christian Wenz <wenz@php.net>
- * @author Michael Cramer <michael@bigmichi1.de>
- * @license http://www.opensource.org/licenses/bsd-license.php BSD License
- * @link http://pear.php.net/package/Text_CAPTCHA
- */
- class Text_CAPTCHA
- {
- /**
- * driver for Text_CAPTCHA
- *
- * @var Text_CAPTCHA_Driver_Base
- */
- private $_driver;
- /**
- * check if an initial driver init was done.
- *
- * @var bool
- */
- private $_driverInitDone = false;
- /**
- * Constructor for the TEXT_CAPTCHA object with the given driver.
- *
- * @param Text_CAPTCHA_Driver $driver driver
- *
- * @throws Text_CAPTCHA_Exception no driver given
- */
- function __construct($driver)
- {
- if (is_null($driver)) {
- throw new Text_CAPTCHA_Exception("No driver given");
- }
- $this->_driver = $driver;
- $this->_driverInitDone = false;
- }
- /**
- * Create a new Text_CAPTCHA object.
- *
- * @param string $driver name of driver class to initialize
- *
- * @return Text_CAPTCHA a newly created Text_CAPTCHA object
- * @throws Text_CAPTCHA_Exception when driver could not be loaded
- *
- */
- public static function factory($driver)
- {
- $driver = basename($driver);
- $class = 'Text_CAPTCHA_Driver_' . $driver;
- $file = str_replace('_', '/', $class) . '.php';
- //check if it exists and can be loaded
- if (!@fclose(@fopen($file, 'r', true))) {
- throw new Text_CAPTCHA_Exception(
- 'Driver ' . $driver . ' cannot be loaded.'
- );
- }
- //continue with including the driver
- include_once $file;
- $driver = new $class;
- return new Text_CAPTCHA($driver);
- }
- /**
- * Create random CAPTCHA phrase
- *
- * @param boolean|string $newPhrase new Phrase to use or true to generate a new
- * one
- *
- * @return void
- * @throws Text_CAPTCHA_Exception when driver is not initialized
- */
- public final function generate($newPhrase = false)
- {
- if (!$this->_driverInitDone) {
- throw new Text_CAPTCHA_Exception("Driver not initialized");
- }
- if ($newPhrase === true || is_null($this->_driver->getPhrase())) {
- $this->_driver->createPhrase();
- } else if (strlen($newPhrase) > 0) {
- $this->_driver->setPhrase($newPhrase);
- }
- $this->_driver->createCAPTCHA();
- }
- /**
- * Reinitialize the entire Text_CAPTCHA object.
- *
- * @param array $options Options to pass in.
- *
- * @return void
- */
- public final function init($options = array())
- {
- $this->_driver->resetDriver();
- $this->_driver->initDriver($options);
- $this->_driverInitDone = true;
- $this->generate();
- }
- /**
- * Place holder for the real getCAPTCHA() method used by extended classes to
- * return the generated CAPTCHA (as an image resource, as an ASCII text, ...).
- *
- * @return string|object
- */
- public final function getCAPTCHA()
- {
- return $this->_driver->getCAPTCHA();
- }
- /**
- * Return secret CAPTCHA phrase.
- *
- * @return string secret phrase
- */
- public final function getPhrase()
- {
- return $this->_driver->getPhrase();
- }
- /**
- * Place holder for the real getCAPTCHA() method used by extended classes to
- * return the generated CAPTCHA (as an image resource, as an ASCII text, ...).
- *
- * @return string|object
- */
- public function getCAPTCHAAsJPEG()
- {
- return $this->_driver->_getCAPTCHAAsJPEG();
- }
- }
|