First commit
This commit is contained in:
commit
c6e2478c40
13918 changed files with 2303184 additions and 0 deletions
118
sites/all/modules/civicrm/Civi/API/Request.php
Normal file
118
sites/all/modules/civicrm/Civi/API/Request.php
Normal file
|
@ -0,0 +1,118 @@
|
|||
<?php
|
||||
/*
|
||||
+--------------------------------------------------------------------+
|
||||
| CiviCRM version 4.7 |
|
||||
+--------------------------------------------------------------------+
|
||||
| Copyright CiviCRM LLC (c) 2004-2017 |
|
||||
+--------------------------------------------------------------------+
|
||||
| This file is a part of CiviCRM. |
|
||||
| |
|
||||
| CiviCRM is free software; you can copy, modify, and distribute it |
|
||||
| under the terms of the GNU Affero General Public License |
|
||||
| Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
|
||||
| |
|
||||
| CiviCRM 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 Affero General Public License for more details. |
|
||||
| |
|
||||
| You should have received a copy of the GNU Affero General Public |
|
||||
| License and the CiviCRM Licensing Exception along |
|
||||
| with this program; if not, contact CiviCRM LLC |
|
||||
| at info[AT]civicrm[DOT]org. If you have questions about the |
|
||||
| GNU Affero General Public License or the licensing of CiviCRM, |
|
||||
| see the CiviCRM license FAQ at http://civicrm.org/licensing |
|
||||
+--------------------------------------------------------------------+
|
||||
*/
|
||||
namespace Civi\API;
|
||||
|
||||
/**
|
||||
* Class Request
|
||||
* @package Civi\API
|
||||
*/
|
||||
class Request {
|
||||
private static $nextId = 1;
|
||||
|
||||
/**
|
||||
* Create a formatted/normalized request object.
|
||||
*
|
||||
* @param string $entity
|
||||
* API entity name.
|
||||
* @param string $action
|
||||
* API action name.
|
||||
* @param array $params
|
||||
* API parameters.
|
||||
* @param mixed $extra
|
||||
* Who knows? ...
|
||||
*
|
||||
* @throws \API_Exception
|
||||
* @return array
|
||||
* the request descriptor; keys:
|
||||
* - version: int
|
||||
* - entity: string
|
||||
* - action: string
|
||||
* - params: array (string $key => mixed $value) [deprecated in v4]
|
||||
* - extra: unspecified
|
||||
* - fields: NULL|array (string $key => array $fieldSpec)
|
||||
* - options: \CRM_Utils_OptionBag derived from params [v4-only]
|
||||
* - data: \CRM_Utils_OptionBag derived from params [v4-only]
|
||||
* - chains: unspecified derived from params [v4-only]
|
||||
*/
|
||||
public static function create($entity, $action, $params, $extra = NULL) {
|
||||
$version = \CRM_Utils_Array::value('version', $params);
|
||||
switch ($version) {
|
||||
default:
|
||||
$apiRequest = array();
|
||||
$apiRequest['id'] = self::$nextId++;
|
||||
$apiRequest['version'] = (int) $version;
|
||||
$apiRequest['params'] = $params;
|
||||
$apiRequest['extra'] = $extra;
|
||||
$apiRequest['fields'] = NULL;
|
||||
$apiRequest['entity'] = self::normalizeEntityName($entity, $apiRequest['version']);
|
||||
$apiRequest['action'] = self::normalizeActionName($action, $apiRequest['version']);
|
||||
return $apiRequest;
|
||||
|
||||
case 4:
|
||||
$callable = array("Civi\\Api4\\Entity\\$entity", $action);
|
||||
if (!is_callable($callable)) {
|
||||
throw new Exception\NotImplementedException("API ($entity, $action) does not exist (join the API team and implement it!)");
|
||||
}
|
||||
$apiCall = call_user_func($callable);
|
||||
$apiRequest['id'] = self::$nextId++;
|
||||
unset($params['version']);
|
||||
foreach ($params as $name => $param) {
|
||||
$setter = 'set' . ucfirst($name);
|
||||
$apiCall->$setter($param);
|
||||
}
|
||||
return $apiCall;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Normalize entity to be CamelCase.
|
||||
*
|
||||
* APIv1-v3 munges entity/action names, and accepts any mixture of case and underscores.
|
||||
*
|
||||
* @param string $entity
|
||||
* @param int $version
|
||||
* @return string
|
||||
*/
|
||||
public static function normalizeEntityName($entity, $version) {
|
||||
return \CRM_Utils_String::convertStringToCamel(\CRM_Utils_String::munge($entity));
|
||||
}
|
||||
|
||||
/**
|
||||
* Normalize api action name to be lowercase.
|
||||
*
|
||||
* APIv1-v3 munges entity/action names, and accepts any mixture of case and underscores.
|
||||
*
|
||||
* @param $action
|
||||
* @param $version
|
||||
* @return string
|
||||
*/
|
||||
public static function normalizeActionName($action, $version) {
|
||||
return strtolower(\CRM_Utils_String::munge($action));
|
||||
}
|
||||
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue