[Bridge] Cleanup documentation and exception messages
This commit is contained in:
parent
6f7b56cba8
commit
fcac5b8b92
1 changed files with 25 additions and 28 deletions
|
@ -12,11 +12,11 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Factory class responsible for creating new instances of bridges from a given
|
* Factory class responsible for creating bridge objects from a given working
|
||||||
* working directory, limited by a whitelist.
|
* directory, limited by a whitelist.
|
||||||
*
|
*
|
||||||
* This class is capable of:
|
* This class is capable of:
|
||||||
* - Locating bridges in the specified working directory (see {@see Bridge::$dirBridge})
|
* - Locating bridge classes in the specified working directory (see {@see Bridge::$dirBridge})
|
||||||
* - Filtering bridges based on a whitelist (see {@see Bridge::$whitelist})
|
* - Filtering bridges based on a whitelist (see {@see Bridge::$whitelist})
|
||||||
* - Creating new bridge instances based on the bridge's name (see {@see Bridge::create()})
|
* - Creating new bridge instances based on the bridge's name (see {@see Bridge::create()})
|
||||||
*
|
*
|
||||||
|
@ -38,7 +38,8 @@
|
||||||
class Bridge {
|
class Bridge {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the working directory.
|
* Holds a path to the working directory.
|
||||||
|
*
|
||||||
* Do not access this property directly!
|
* Do not access this property directly!
|
||||||
* Use {@see Bridge::setWorkingDir()} and {@see Bridge::getWorkingDir()} instead.
|
* Use {@see Bridge::setWorkingDir()} and {@see Bridge::getWorkingDir()} instead.
|
||||||
*
|
*
|
||||||
|
@ -47,7 +48,8 @@ class Bridge {
|
||||||
static protected $dirBridge;
|
static protected $dirBridge;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the whitelist.
|
* Holds a list of whitelisted bridges.
|
||||||
|
*
|
||||||
* Do not access this property directly!
|
* Do not access this property directly!
|
||||||
* Use {@see Bridge::getWhitelist()} instead.
|
* Use {@see Bridge::getWhitelist()} instead.
|
||||||
*
|
*
|
||||||
|
@ -60,36 +62,31 @@ class Bridge {
|
||||||
* Use {@see Bridge::create()} to instanciate a new bridge from the working
|
* Use {@see Bridge::create()} to instanciate a new bridge from the working
|
||||||
* directory.
|
* directory.
|
||||||
*
|
*
|
||||||
* @throws LogicException if called.
|
* @throws \LogicException if called.
|
||||||
*/
|
*/
|
||||||
public function __construct(){
|
public function __construct(){
|
||||||
throw new \LogicException('Please use ' . __CLASS__ . '::create for new object.');
|
throw new \LogicException('Use ' . __CLASS__ . '::create($name) to create bridge objects!');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a new instance of a bridge in the working directory.
|
* Creates a new bridge object from the working directory.
|
||||||
*
|
*
|
||||||
* @throws InvalidArgumentException if the provided bridge name is invalid.
|
* @throws \InvalidArgumentException if the requested bridge name is invalid.
|
||||||
* @throws Exception if a bridge with the given name does not exist in the
|
* @throws \Exception if the requested bridge doesn't exist in the working
|
||||||
* working directory.
|
* directory.
|
||||||
* @param string $nameBridge Name of the bridge.
|
* @param string $nameBridge Name of the bridge object.
|
||||||
* @return object|bool Instance of the bridge or false if the bridge is not instantiable.
|
* @return object|bool The bridge object or false if the class is not instantiable.
|
||||||
*/
|
*/
|
||||||
public static function create($nameBridge){
|
public static function create($nameBridge){
|
||||||
if(!preg_match('@^[A-Z][a-zA-Z0-9-]*$@', $nameBridge)) {
|
if(!preg_match('@^[A-Z][a-zA-Z0-9-]*$@', $nameBridge)) {
|
||||||
$message = <<<EOD
|
throw new \InvalidArgumentException('Bridge name invalid!');
|
||||||
'nameBridge' must start with one uppercase character followed or not by
|
|
||||||
alphanumeric or dash characters!
|
|
||||||
EOD;
|
|
||||||
throw new \InvalidArgumentException($message);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$nameBridge = Bridge::sanitizeBridgeName($nameBridge) . 'Bridge';
|
$nameBridge = Bridge::sanitizeBridgeName($nameBridge) . 'Bridge';
|
||||||
$pathBridge = self::getWorkingDir() . $nameBridge . '.php';
|
$pathBridge = self::getWorkingDir() . $nameBridge . '.php';
|
||||||
|
|
||||||
if(!file_exists($pathBridge)) {
|
if(!file_exists($pathBridge)) {
|
||||||
throw new \Exception('The bridge you are looking for does not exist. It should be at path '
|
throw new \Exception('Cache file ' . $pathBridge . ' does not exist!');
|
||||||
. $pathBridge);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
require_once $pathBridge;
|
require_once $pathBridge;
|
||||||
|
@ -102,35 +99,35 @@ EOD;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the current working directory.
|
* Sets the working directory.
|
||||||
*
|
*
|
||||||
* @param string $dirBridge Path to the directory containing bridges.
|
* @param string $dirBridge Path to the directory containing bridges.
|
||||||
* @throws LogicException if the provided path is not a valid string.
|
* @throws \LogicException if the provided path is not a valid string.
|
||||||
* @throws Exception if the provided path does not exist.
|
* @throws \Exception if the provided path does not exist.
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public static function setWorkingDir($dirBridge){
|
public static function setWorkingDir($dirBridge){
|
||||||
if(!is_string($dirBridge)) {
|
if(!is_string($dirBridge)) {
|
||||||
throw new \InvalidArgumentException('Dir bridge must be a string.');
|
throw new \InvalidArgumentException('Working directory is not a valid string!');
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!file_exists($dirBridge)) {
|
if(!file_exists($dirBridge)) {
|
||||||
throw new \Exception('Dir bridge does not exist.');
|
throw new \Exception('Working directory does not exist!');
|
||||||
}
|
}
|
||||||
|
|
||||||
self::$dirBridge = $dirBridge;
|
self::$dirBridge = $dirBridge;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the current working directory.
|
* Returns the working directory.
|
||||||
* The working directory must be specified with {@see Bridge::setWorkingDir()}!
|
* The working directory must be specified with {@see Bridge::setWorkingDir()}!
|
||||||
*
|
*
|
||||||
* @throws LogicException if the working directory was not specified.
|
* @throws \LogicException if the working directory is not set.
|
||||||
* @return string The current working directory.
|
* @return string The current working directory.
|
||||||
*/
|
*/
|
||||||
public static function getWorkingDir(){
|
public static function getWorkingDir(){
|
||||||
if(is_null(self::$dirBridge)) {
|
if(is_null(self::$dirBridge)) {
|
||||||
throw new \LogicException(__CLASS__ . ' class need to know bridge path !');
|
throw new \LogicException('Working directory is not set!');
|
||||||
}
|
}
|
||||||
|
|
||||||
return self::$dirBridge;
|
return self::$dirBridge;
|
||||||
|
|
Loading…
Reference in a new issue