2007-03-09 23:15:03 +00:00
< ? php
2007-03-27 05:10:42 +00:00
/* SVN FILE: $Id$ */
/**
* Short description for file .
*
* Long description for file
*
* PHP versions 4 and 5
*
* CakePHP ( tm ) : Rapid Development Framework < http :// www . cakephp . org />
* Copyright 2005 - 2007 , Cake Software Foundation , Inc .
* 1785 E . Sahara Avenue , Suite 490 - 204
* Las Vegas , Nevada 89104
*
* Licensed under The MIT License
* Redistributions of files must retain the above copyright notice .
*
* @ filesource
* @ copyright Copyright 2005 - 2007 , Cake Software Foundation , Inc .
* @ link http :// www . cakefoundation . org / projects / info / cakephp CakePHP ( tm ) Project
* @ package cake
* @ subpackage cake . cake . scripts
* @ since CakePHP ( tm ) v 1.2 . 0.4604
* @ version $Revision $
* @ modifiedby $LastChangedBy $
* @ lastmodified $Date $
* @ license http :// www . opensource . org / licenses / mit - license . php The MIT License
*/
2007-03-09 23:15:03 +00:00
/**
* Base class for command - line utilities for automating programmer chores .
*
* @ package cake
* @ subpackage cake . cake . scripts
*/
2007-05-03 22:40:22 +00:00
class CakeScript extends Object {
2007-03-09 23:15:03 +00:00
/**
* ConsoleDispatcher object
*
* @ var object An instance of the ConsoleDispatcher object that loaded this script
*/
var $dispatch = null ;
/**
* If true , the script will ask for permission to perform actions .
*
* @ var boolean
*/
var $interactive = true ;
/**
* Holds the DATABASE_CONFIG object for the app . Null if database . php could not be found ,
* or the app does not exist .
*
* @ var object
*/
var $dbConfig = null ;
/**
* Contains command switches parsed from the command line .
*
* @ var array
*/
var $params = array ();
/**
* Contains arguments parsed from the command line .
*
* @ var array
*/
var $args = array ();
/**
2007-05-04 00:25:04 +00:00
* Constructs this CakeScript instance .
2007-03-09 23:15:03 +00:00
*
*/
function __construct ( & $dispatch ) {
2007-05-04 03:49:53 +00:00
$this -> Dispatch = & $dispatch ;
$this -> params = & $this -> Dispatch -> params ;
$this -> args = & $this -> Dispatch -> args ;
$this -> name = & $this -> Dispatch -> scriptName ;
$this -> command = & $this -> Dispatch -> scriptCommand ;
2007-05-04 00:25:04 +00:00
}
/**
* Initializes the CakeScript
* can be overriden in subclasses
*
* @ return null
2007-05-04 03:49:53 +00:00
*/
2007-05-04 00:25:04 +00:00
function initialize () {
2007-05-03 21:14:46 +00:00
if ( $this -> _loadDbConfig ()) {
$this -> _loadModel ();
2007-03-09 23:15:03 +00:00
}
}
2007-05-04 00:25:04 +00:00
/**
* Loads database file and constructs DATABASE_CONFIG class
* makes $this -> dbConfig available to subclasses
*
* @ return bool
*/
2007-05-03 21:14:46 +00:00
function _loadDbConfig () {
if ( config ( 'database' )) {
if ( class_exists ( 'DATABASE_CONFIG' )) {
$this -> dbConfig = new DATABASE_CONFIG ();
return true ;
}
}
2007-05-04 00:25:04 +00:00
$this -> err ( 'Database config could not be loaded' );
2007-05-03 21:14:46 +00:00
return false ;
}
2007-05-04 00:25:04 +00:00
/**
* Loads AppModel file and constructs AppModel class
* makes $this -> AppModel available to subclasses
*
* @ return bool
*/
2007-05-03 21:14:46 +00:00
function _loadModel () {
uses ( 'model' . DS . 'connection_manager' ,
'model' . DS . 'datasources' . DS . 'dbo_source' , 'model' . DS . 'model'
);
if ( loadModel ()) {
$this -> AppModel = & new AppModel ();
return true ;
}
2007-05-04 00:25:04 +00:00
$this -> err ( 'AppModel could not be loaded' );
2007-05-03 21:14:46 +00:00
return false ;
}
2007-03-09 23:15:03 +00:00
/**
* Main - loop method .
*
*/
2007-05-04 04:37:25 +00:00
function bake () {
2007-05-04 03:49:53 +00:00
2007-03-09 23:15:03 +00:00
$this -> out ( '' );
$this -> out ( '' );
$this -> out ( 'Baking...' );
$this -> hr ();
$this -> out ( 'Name: ' . APP_DIR );
2007-05-03 21:14:46 +00:00
$this -> out ( 'Path: ' . ROOT . DS . APP_DIR );
2007-03-09 23:15:03 +00:00
$this -> hr ();
if ( empty ( $this -> dbConfig )) {
$this -> out ( '' );
2007-05-04 04:37:25 +00:00
$this -> err ( 'Your database configuration was not found. Take a moment to create one:' );
exit ();
2007-03-09 23:15:03 +00:00
}
require_once ( CONFIGS . 'database.php' );
2007-03-27 05:10:42 +00:00
2007-03-09 23:15:03 +00:00
$this -> stdout ( '[M]odel' );
$this -> stdout ( '[C]ontroller' );
$this -> stdout ( '[V]iew' );
$invalidSelection = true ;
while ( $invalidSelection ) {
$classToBake = strtoupper ( $this -> in ( 'What would you like to Bake?' , array ( 'M' , 'V' , 'C' )));
switch ( $classToBake ) {
case 'M' :
$invalidSelection = false ;
$this -> doModel ();
break ;
case 'V' :
$invalidSelection = false ;
$this -> doView ();
break ;
case 'C' :
$invalidSelection = false ;
$this -> doController ();
break ;
default :
$this -> stdout ( 'You have made an invalid selection. Please choose a type of class to Bake by entering M, V, or C.' );
}
}
}
/**
* Prompts the user for input , and returns it .
*
* @ param string $prompt Prompt text .
* @ param mixed $options Array or string of options .
* @ param string $default Default input value .
* @ return Either the default value , or the user - provided input .
*/
function in ( $prompt , $options = null , $default = null ) {
2007-05-04 03:49:53 +00:00
return $this -> Dispatch -> getInput ( $prompt , $options , $default );
2007-03-09 23:15:03 +00:00
}
/**
* Outputs to the stdout filehandle .
*
* @ param string $string String to output .
* @ param boolean $newline If true , the outputs gets an added newline .
*/
function out ( $string , $newline = true ) {
2007-05-04 03:49:53 +00:00
return $this -> Dispatch -> stdout ( $string , $newline );
2007-03-09 23:15:03 +00:00
}
/**
* Outputs to the stderr filehandle .
*
* @ param string $string Error text to output .
*/
function err ( $string ) {
2007-05-04 04:37:25 +00:00
return $this -> Dispatch -> stderr ( $string . " \n " );
2007-03-09 23:15:03 +00:00
}
/**
* Outputs a series of minus characters to the standard output , acts as a visual separator .
*
*/
2007-05-02 18:41:55 +00:00
function hr ( $newline = false ) {
if ( $newline ) {
$this -> out ( " \n " );
}
2007-03-09 23:15:03 +00:00
$this -> out ( '---------------------------------------------------------------' );
2007-05-02 18:41:55 +00:00
if ( $newline ) {
$this -> out ( " \n " );
}
2007-03-09 23:15:03 +00:00
}
2007-05-04 03:49:53 +00:00
/**
* Displays a formatted error message
*
* @ param unknown_type $title
* @ param unknown_type $msg
*/
function displayError ( $title , $msg ) {
$out = " \n " ;
$out .= " Error: $title\n " ;
$out .= " $msg\n " ;
$out .= " \n " ;
$this -> out ( $out );
exit ();
}
/**
* Will check the number args matches otherwise throw an error
*
* @ param unknown_type $expectedNum
* @ param unknown_type $command
*/
function checkArgNumber ( $expectedNum , $command = null ) {
if ( ! $command ) {
$command = $this -> command ;
}
if ( count ( $this -> args ) < $expectedNum ) {
$this -> displayError ( 'Wrong number of parameters: ' . count ( $this -> args ), 'Please type \'cake ' . $this -> Dispatch -> script . ' help\' for help on usage of the ' . $command . ' command.' );
}
}
2007-03-09 23:15:03 +00:00
/**
* Creates a file at given path .
*
* @ param string $path Where to put the file .
* @ param string $contents Content to put in the file .
* @ return Success
*/
function createFile ( $path , $contents ) {
$path = str_replace ( DS . DS , DS , $path );
echo " \n Creating file $path\n " ;
if ( is_file ( $path ) && $this -> interactive === true ) {
2007-05-03 21:14:46 +00:00
$this -> out ( __ ( " File exists, overwrite? " , true ) . " { $path } (y/n/q): " );
2007-03-09 23:15:03 +00:00
$key = trim ( fgets ( $this -> stdin ));
if ( $key == 'q' ) {
2007-05-03 21:14:46 +00:00
$this -> out ( __ ( " Quitting. " , true ) . " \n " );
2007-03-09 23:15:03 +00:00
exit ;
} elseif ( $key == 'a' ) {
$this -> dont_ask = true ;
} elseif ( $key == 'y' ) {
} else {
2007-05-03 21:14:46 +00:00
$this -> out ( __ ( " Skip " , true ) . " { $path } \n " );
2007-03-09 23:15:03 +00:00
return false ;
}
}
2007-05-04 03:49:53 +00:00
2007-05-03 23:22:02 +00:00
uses ( 'file' );
if ( $File = new File ( $path , true )) {
$File -> write ( $contents );
2007-05-03 21:14:46 +00:00
$this -> out ( __ ( " Wrote " , true ) . " { $path } \n " );
2007-03-09 23:15:03 +00:00
return true ;
} else {
2007-05-03 21:14:46 +00:00
$this -> err ( __ ( " Error! Could not write to " , true ) . " { $path } . \n " );
2007-03-09 23:15:03 +00:00
return false ;
}
}
/**
* Outputs usage text on the standard output .
*
*/
function help () {
$this -> stdout ( 'CakePHP Console:' );
$this -> hr ();
$this -> stdout ( 'The Bake script generates controllers, views and models for your application.' );
$this -> stdout ( 'If run with no command line arguments, Bake guides the user through the class' );
$this -> stdout ( 'creation process. You can customize the generation process by telling Bake' );
$this -> stdout ( 'where different parts of your application are using command line arguments.' );
$this -> stdout ( '' );
$this -> hr ( '' );
$this -> stdout ( 'usage: php bake.php [command] [path...]' );
$this -> stdout ( '' );
$this -> stdout ( 'commands:' );
$this -> stdout ( ' -app [path...] Absolute path to Cake\'s app Folder.' );
$this -> stdout ( ' -core [path...] Absolute path to Cake\'s cake Folder.' );
$this -> stdout ( ' -help Shows this help message.' );
$this -> stdout ( ' -project [path...] Generates a new app folder in the path supplied.' );
$this -> stdout ( ' -root [path...] Absolute path to Cake\'s \app\webroot Folder.' );
$this -> stdout ( '' );
}
/**
* Returns true if given path is a directory .
*
* @ param string $path
* @ return True if given path is a directory .
*/
function isDir ( $path ) {
if ( is_dir ( $path )) {
return true ;
} else {
return false ;
}
}
/**
* Recursive directory copy .
*
* @ param string $fromDir
* @ param string $toDir
* @ param octal $chmod
* @ param boolean $verbose
* @ return Success .
*/
function copyDir ( $fromDir , $toDir , $chmod = 0755 , $verbose = false ) {
$errors = array ();
$messages = array ();
if ( ! is_dir ( $toDir )) {
uses ( 'folder' );
$folder = new Folder ();
$folder -> mkdirr ( $toDir , 0755 );
}
if ( ! is_writable ( $toDir )) {
$errors [] = 'target ' . $toDir . ' is not writable' ;
}
if ( ! is_dir ( $fromDir )) {
$errors [] = 'source ' . $fromDir . ' is not a directory' ;
}
if ( ! empty ( $errors )) {
if ( $verbose ) {
foreach ( $errors as $err ) {
$this -> stdout ( 'Error: ' . $err );
}
}
return false ;
}
$exceptions = array ( '.' , '..' , '.svn' );
$handle = opendir ( $fromDir );
while ( false !== ( $item = readdir ( $handle ))) {
if ( ! in_array ( $item , $exceptions )) {
$from = str_replace ( '//' , '/' , $fromDir . '/' . $item );
$to = str_replace ( '//' , '/' , $toDir . '/' . $item );
if ( is_file ( $from )) {
if ( @ copy ( $from , $to )) {
chmod ( $to , $chmod );
touch ( $to , filemtime ( $from ));
$messages [] = 'File copied from ' . $from . ' to ' . $to ;
} else {
$errors [] = 'cannot copy file from ' . $from . ' to ' . $to ;
}
}
if ( is_dir ( $from )) {
if ( @ mkdir ( $to )) {
chmod ( $to , $chmod );
$messages [] = 'Directory created: ' . $to ;
} else {
$errors [] = 'cannot create directory ' . $to ;
}
$this -> copyDir ( $from , $to , $chmod , $verbose );
}
}
}
closedir ( $handle );
if ( $verbose ) {
foreach ( $errors as $err ) {
$this -> stdout ( 'Error: ' . $err );
}
foreach ( $messages as $msg ) {
$this -> stdout ( $msg );
}
}
return true ;
}
function __addAdminRoute ( $name ){
$file = file_get_contents ( CONFIGS . 'core.php' );
if ( preg_match ( '%([/\\t\\x20]*define\\(\'CAKE_ADMIN\',[\\t\\x20\'a-z]*\\);)%' , $file , $match )) {
$result = str_replace ( $match [ 0 ], 'define(\'CAKE_ADMIN\', \'' . $name . '\');' , $file );
if ( file_put_contents ( CONFIGS . 'core.php' , $result )){
return true ;
} else {
return false ;
}
} else {
return false ;
}
}
}
?>