%PDF- %PDF-
| Direktori : /www/loslex_o/tracker/core/commands/ |
| Current File : /www/loslex_o/tracker/core/commands/Command.php |
<?php
# MantisBT - A PHP based bugtracking system
# MantisBT is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 2 of the License, or
# (at your option) any later version.
#
# MantisBT is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with MantisBT. If not, see <http://www.gnu.org/licenses/>.
/**
* A base class for intent based commands that can accomplish a task.
* Such commands will be used from web ui action pages, REST API, SOAP API, etc.
* This provides consistency across such callers while being agnostic of the
* caller.
*
* The command pattern will build on top of model, APIs, configurations, and
* authorization.
*/
abstract class Command
{
/**
* This is the data for the command. Modelled after the REST
* it has the following sub-arrays:
* 'query' - an array of url and query string parameters.
* 'payload' - the payload
* 'options' - options specified by the internal codebase and not
* as part of the request.
*
* @var array The input data for the command.
*/
protected $data;
/**
* Command constructor taking in all required data to execute the command.
*
* @param array $p_data The command data.
*/
function __construct( array $p_data ) {
$this->data = $p_data;
}
/**
* Make sure that provided data is valid and update data with default
* value that are missing.
*
* @return void
*/
abstract protected function validate();
/**
* The core execution of the command (e.g. assigning an issue) with no knowledge
* about side effects of such execution, e.g. an email will be sent via a post processor.
*
* @return array The results of the command processing that goes into $executionResults
*/
abstract protected function process();
/**
* Gets the value of the option or default.
*
* @param string $p_name The option name.
* @param mixed $p_default The default value.
*
* @return mixed The option value or its default.
*/
public function option( $p_name, $p_default = null ) {
if( isset( $this->data['options'][$p_name] ) ) {
return $this->data['options'][$p_name];
}
return $p_default;
}
/**
* Gets the value of a payload field or its default.
*
* @param string $p_name The field name.
* @param mixed $p_default The default value.
*
* @return mixed The payload field value or its default.
*/
public function payload( $p_name, $p_default = null ) {
if( isset( $this->data['payload'][$p_name] ) ) {
return $this->data['payload'][$p_name];
}
return $p_default;
}
/**
* Gets the value of a query field or its default.
*
* @param string $p_name The field name.
* @param mixed $p_default The default value.
*
* @return mixed The field value or its default.
*/
public function query( $p_name, $p_default = null ) {
if( isset( $this->data['query'][$p_name] ) ) {
return $this->data['query'][$p_name];
}
return $p_default;
}
/**
* Execute the command. This may throw a CommandException is execution is interrupted.
* The command is expected to trigger events that are handled by plugins as part of
* execution.
*
* @return array Execution result
*/
public function execute() {
# For now, all commands require user to be authenticated
auth_ensure_user_authenticated();
if( !isset( $this->data['payload'] ) ) {
$this->data['payload'] = array();
}
if( !isset( $this->data['query'] ) ) {
$this->data['query'] = array();
}
if( !isset( $this->data['options'] ) ) {
$this->data['options'] = array();
}
$this->validate();
return $this->process();
}
}