Class SchemacacheClearCommand
Provides CLI tool for clearing schema cache.
Property Summary
- 
        $_modelFactories protectedarray<callable|Cake\Datasource\Locator\LocatorInterface>A list of overridden model factory functions. 
- 
        $_modelType protectedstringThe model type to use. 
- 
        $_tableLocator protectedCake\ORM\Locator\LocatorInterface|nullTable locator instance 
- 
        $defaultTable protectedstring|nullThis object's default table alias. 
- 
        $modelClass protectedstring|nullThis object's primary model class name. Should be a plural form. CakePHP will not inflect the name. 
- 
        $name protectedstringThe name of this command. 
Method Summary
- 
          __construct() publicConstructor 
- 
          _setModelClass() protectedSet the modelClass property based on conventions. 
- 
          abort() publicHalt the current process with a StopException. 
- 
          buildOptionParser() publicGet the option parser. 
- 
          defaultName() public staticGet the command name. 
- 
          displayHelp() protectedOutput help content 
- 
          execute() publicDisplay all routes in an application 
- 
          executeCommand() publicExecute another command with the provided set of arguments. 
- 
          fetchModel() publicFetch or construct a model instance from a locator. 
- 
          fetchTable() publicConvenience method to get a table instance. 
- 
          getDescription() public staticGet the command description. 
- 
          getModelType() publicGet the model type to be used by this class 
- 
          getName() publicGet the command name. 
- 
          getOptionParser() publicGet the option parser. 
- 
          getRootName() publicGet the root command name. 
- 
          getTableLocator() publicGets the table locator. 
- 
          initialize() publicHook method invoked by CakePHP when a command is about to be executed. 
- 
          loadModel() public deprecatedFetch or construct a model and set it to a property on this object. 
- 
          log() publicConvenience method to write a message to Log. See Log::write() for more information on writing to logs. 
- 
          modelFactory() publicOverride a existing callable to generate repositories of a given type. 
- 
          run() publicRun the command. 
- 
          setModelType() publicSet the model type to be used by this class 
- 
          setName() publicSet the name this command uses in the collection. 
- 
          setOutputLevel() protectedSet the output level based on the Arguments. 
- 
          setTableLocator() publicSets the table locator. 
Method Detail
__construct() ¶ public
__construct()Constructor
By default CakePHP will construct command objects when building the CommandCollection for your application.
_setModelClass() ¶ protected
_setModelClass(string $name): voidSet the modelClass property based on conventions.
If the property is already set it will not be overwritten
Parameters
- 
                string$name
- Class name. 
Returns
voidabort() ¶ public
abort(int $code = self::CODE_ERROR): voidHalt the current process with a StopException.
Parameters
- 
                int$code optional
- The exit code to use. 
Returns
voidThrows
Cake\Console\Exception\StopExceptionbuildOptionParser() ¶ public
buildOptionParser(Cake\Console\ConsoleOptionParser $parser): Cake\Console\ConsoleOptionParserGet the option parser.
Parameters
- 
                Cake\Console\ConsoleOptionParser$parser
- The option parser to update 
Returns
Cake\Console\ConsoleOptionParserdefaultName() ¶ public static
defaultName(): stringGet the command name.
Returns the command name based on class name.
For e.g. for a command with class name UpdateTableCommand the default
name returned would be 'update_table'.
Returns
stringdisplayHelp() ¶ protected
displayHelp(Cake\Console\ConsoleOptionParser $parser, Cake\Console\Arguments $args, Cake\Console\ConsoleIo $io): voidOutput help content
Parameters
- 
                Cake\Console\ConsoleOptionParser$parser
- The option parser. 
- 
                Cake\Console\Arguments$args
- The command arguments. 
- 
                Cake\Console\ConsoleIo$io
- The console io 
Returns
voidexecute() ¶ public
execute(Cake\Console\Arguments $args, Cake\Console\ConsoleIo $io): int|nullDisplay all routes in an application
Parameters
- 
                Cake\Console\Arguments$args
- The command arguments. 
- 
                Cake\Console\ConsoleIo$io
- The console io 
Returns
int|nullexecuteCommand() ¶ public
executeCommand(Cake\Console\CommandInterface|string $command, array $args = [], Cake\Console\ConsoleIo|null $io = null): int|nullExecute another command with the provided set of arguments.
If you are using a string command name, that command's dependencies will not be resolved with the application container. Instead you will need to pass the command as an object with all of its dependencies.
Parameters
- 
                Cake\Console\CommandInterface|string$command
- The command class name or command instance. 
- 
                array$args optional
- The arguments to invoke the command with. 
- 
                Cake\Console\ConsoleIo|null$io optional
- The ConsoleIo instance to use for the executed command. 
Returns
int|nullfetchModel() ¶ public
fetchModel(string|null $modelClass = null, string|null $modelType = null): Cake\Datasource\RepositoryInterfaceFetch or construct a model instance from a locator.
Uses a modelFactory based on $modelType to fetch and construct a RepositoryInterface
and return it. The default modelType can be defined with setModelType().
Unlike loadModel() this method will not set an object property.
If a repository provider does not return an object a MissingModelException will be thrown.
Parameters
- 
                string|null$modelClass optional
- Name of model class to load. Defaults to $this->modelClass. The name can be an alias like - 'Post'or FQCN like- App\Model\Table\PostsTable::class.
- 
                string|null$modelType optional
- The type of repository to load. Defaults to the getModelType() value. 
Returns
Cake\Datasource\RepositoryInterfaceThrows
Cake\Datasource\Exception\MissingModelExceptionIf the model class cannot be found.
UnexpectedValueExceptionIf $modelClass argument is not provided and ModelAwareTrait::$modelClass property value is empty.
fetchTable() ¶ public
fetchTable(string|null $alias = null, array<string, mixed> $options = []): Cake\ORM\TableConvenience method to get a table instance.
Parameters
- 
                string|null$alias optional
- The alias name you want to get. Should be in CamelCase format. If - nullthen the value of $defaultTable property is used.
- 
                array<string, mixed>$options optional
- The options you want to build the table with. If a table has already been loaded the registry options will be ignored. 
Returns
Cake\ORM\TableThrows
Cake\Core\Exception\CakeExceptionIf `$alias` argument and `$defaultTable` property both are `null`.
See Also
getDescription() ¶ public static
getDescription(): stringGet the command description.
Returns
stringgetModelType() ¶ public
getModelType(): stringGet the model type to be used by this class
Returns
stringgetOptionParser() ¶ public
getOptionParser(): Cake\Console\ConsoleOptionParserGet the option parser.
You can override buildOptionParser() to define your options & arguments.
Returns
Cake\Console\ConsoleOptionParserThrows
RuntimeExceptionWhen the parser is invalid
getTableLocator() ¶ public
getTableLocator(): Cake\ORM\Locator\LocatorInterfaceGets the table locator.
Returns
Cake\ORM\Locator\LocatorInterfaceinitialize() ¶ public
initialize(): voidHook method invoked by CakePHP when a command is about to be executed.
Override this method and implement expensive/important setup steps that should not run on every command run. This method will be called before the options and arguments are validated and processed.
Returns
voidloadModel() ¶ public
loadModel(string|null $modelClass = null, string|null $modelType = null): Cake\Datasource\RepositoryInterfaceFetch or construct a model and set it to a property on this object.
Uses a modelFactory based on $modelType to fetch and construct a RepositoryInterface
and set it as a property on the current object. The default modelType
can be defined with setModelType().
If a repository provider does not return an object a MissingModelException will be thrown.
Parameters
- 
                string|null$modelClass optional
- Name of model class to load. Defaults to $this->modelClass. The name can be an alias like - 'Post'or FQCN like- App\Model\Table\PostsTable::class.
- 
                string|null$modelType optional
- The type of repository to load. Defaults to the getModelType() value. 
Returns
Cake\Datasource\RepositoryInterfaceThrows
Cake\Datasource\Exception\MissingModelExceptionIf the model class cannot be found.
UnexpectedValueExceptionIf $modelClass argument is not provided and ModelAwareTrait::$modelClass property value is empty.
log() ¶ public
log(string $message, string|int $level = LogLevel::ERROR, array|string $context = []): boolConvenience method to write a message to Log. See Log::write() for more information on writing to logs.
Parameters
- 
                string$message
- Log message. 
- 
                string|int$level optional
- Error level. 
- 
                array|string$context optional
- Additional log data relevant to this message. 
Returns
boolmodelFactory() ¶ public
modelFactory(string $type, Cake\Datasource\Locator\LocatorInterface|callable $factory): voidOverride a existing callable to generate repositories of a given type.
Parameters
- 
                string$type
- The name of the repository type the factory function is for. 
- 
                Cake\Datasource\Locator\LocatorInterface|callable$factory
- The factory function used to create instances. 
Returns
voidrun() ¶ public
run(array $argv, Cake\Console\ConsoleIo $io): int|nullRun the command.
Parameters
- 
                array$argv
- 
                Cake\Console\ConsoleIo$io
Returns
int|nullsetModelType() ¶ public
setModelType(string $modelType): $thisSet the model type to be used by this class
Parameters
- 
                string$modelType
- The model type 
Returns
$thissetName() ¶ public
setName(string $name): $thisSet the name this command uses in the collection.
Generally invoked by the CommandCollection when the command is added. Required to have at least one space in the name so that the root command can be calculated.
Parameters
- 
                string$name
Returns
$thissetOutputLevel() ¶ protected
setOutputLevel(Cake\Console\Arguments $args, Cake\Console\ConsoleIo $io): voidSet the output level based on the Arguments.
Parameters
- 
                Cake\Console\Arguments$args
- The command arguments. 
- 
                Cake\Console\ConsoleIo$io
- The console io 
Returns
voidsetTableLocator() ¶ public
setTableLocator(Cake\ORM\Locator\LocatorInterface $tableLocator): $thisSets the table locator.
Parameters
- 
                Cake\ORM\Locator\LocatorInterface$tableLocator
- LocatorInterface instance. 
Returns
$thisProperty Detail
$_modelFactories ¶ protected
A list of overridden model factory functions.
Type
array<callable|Cake\Datasource\Locator\LocatorInterface>$modelClass ¶ protected
This object's primary model class name. Should be a plural form. CakePHP will not inflect the name.
Example: For an object named 'Comments', the modelClass would be 'Comments'.
Plugin classes should use Plugin.Comments style names to correctly load
models from the correct plugin.
Use empty string to not use auto-loading on this object. Null auto-detects based on controller name.
Type
string|null