<?php
-// $Id$
-
/*
+--------------------------------------------------------------------+
- | CiviCRM version 4.3 |
+ | CiviCRM version 4.4 |
+--------------------------------------------------------------------+
| Copyright CiviCRM LLC (c) 2004-2013 |
+--------------------------------------------------------------------+
}
if (!empty($params['home_url'])) {
- $websiteTypes = CRM_Core_PseudoConstant::websiteType();
+ $websiteTypes = CRM_Core_PseudoConstant::get('CRM_Core_DAO_Website', 'website_type_id');
$params['website'] = array(1 => array('website_type_id' => key($websiteTypes),
'url' => $params['home_url'],
),
);
}
- if (isset($params['suffix_id']) && !(is_numeric($params['suffix_id']))) {
- $params['suffix_id'] = array_search($params['suffix_id'], CRM_Core_PseudoConstant::individualSuffix());
- }
-
- if (isset($params['prefix_id']) && !(is_numeric($params['prefix_id']))) {
- $params['prefix_id'] = array_search($params['prefix_id'], CRM_Core_PseudoConstant::individualPrefix());
- }
-
- if (isset($params['gender_id']) && !(is_numeric($params['gender_id']))) {
- $params['gender_id'] = array_search($params['gender_id'], CRM_Core_PseudoConstant::gender());
- }
-
- $error = _civicrm_api3_greeting_format_params($params);
- if (civicrm_error($error)) {
- return $error;
- }
+ _civicrm_api3_greeting_format_params($params);
$values = array();
- $entityId = $contactID;
- if (empty($params['contact_type']) && $entityId) {
- $params['contact_type'] = CRM_Contact_BAO_Contact::getContactType($entityId);
+ if (empty($params['contact_type']) && $contactID) {
+ $params['contact_type'] = CRM_Contact_BAO_Contact::getContactType($contactID);
}
- if (!isset($params['contact_sub_type']) && $entityId) {
- $params['contact_sub_type'] = CRM_Contact_BAO_Contact::getContactSubType($entityId);
+ if (!isset($params['contact_sub_type']) && $contactID) {
+ $params['contact_sub_type'] = CRM_Contact_BAO_Contact::getContactSubType($contactID);
}
- _civicrm_api3_custom_format_params($params, $values, $params['contact_type'], $entityId);
+ _civicrm_api3_custom_format_params($params, $values, $params['contact_type'], $contactID);
$params = array_merge($params, $values);
-
+ //@todo we should just call basic_create here - but need to make contact:create accept 'id' on the bao
$contact = _civicrm_api3_contact_update($params, $contactID);
if (is_a($contact, 'CRM_Core_Error')) {
- return civicrm_api3_create_error($contact->_errors[0]['message']);
+ throw new API_Exception($contact->_errors[0]['message']);
}
else {
$values = array();
$params['current_employer'] = array(
'title' => 'Current Employer',
'description' => 'Name of Current Employer',
+ 'type' => CRM_Utils_Type::T_STRING,
);
$params['dupe_check'] = array(
'title' => 'Check for Duplicates',
'description' => 'Throw error if contact create matches dedupe rule',
);
+ $params['prefix_id']['api.aliases'] = array('individual_prefix', 'individual_prefix_id');
+ $params['suffix_id']['api.aliases'] = array('individual_suffix', 'individual_suffix_id');
}
/**
$options = array();
_civicrm_api3_contact_get_supportanomalies($params, $options);
$contacts = _civicrm_api3_get_using_query_object('contact', $params, $options);
-
- // CRM-7929 Quick fix by colemanw
- // TODO: Figure out what function is responsible for prepending 'individual_' to these keys
- // and sort it out there rather than going to all this trouble here.
- // Eileen's note - not sure anymore if we went the right path stripping the 'individual' here
- // as is arguable whether it makes more sense now I think it would make more sense to rename the table field or uniquefield to have
- // the individual prefix but we are stuck with it now for apiv3 series.
- $returnContacts = array();
- if (is_array($contacts)) {
- foreach ($contacts as $cid => $contact) {
- if (is_array($contact)) {
- $returnContacts[$cid] = array();
- foreach ($contact as $key => $value) {
- $key = str_replace(array('individual_prefix', 'individual_suffix'), array('prefix', 'suffix'), $key);
- $returnContacts[$cid][$key] = $value;
- }
- }
- }
- }
- return civicrm_api3_create_success($returnContacts, $params, 'contact');
+ return civicrm_api3_create_success($contacts, $params, 'contact');
}
function civicrm_api3_contact_getcount($params) {
$options = array();
_civicrm_api3_contact_get_supportanomalies($params, $options);
$count = _civicrm_api3_get_using_query_object('contact', $params, $options,1);
- return $count;
+ return (int) $count;
}
/**
$params['worldregion_id']['title'] = 'Primary Address World Region ID';
$params['worldregion']['title'] = 'Primary Address World Region';
$params['phone_id']['title'] = 'Primary Phone ID';
+ $params['phone']['title'] = 'Primary Phone';
$params['phone_type_id']['title'] = 'Primary Phone Type ID';
$params['provider_id']['title'] = 'Primary Phone Provider ID';
$params['email_id']['title'] = 'Primary Email ID';
$params['email']['title'] = 'Primary Email';
+ $params['gender_id']['title'] = 'Gender ID';
+ $params['gender']['title'] = 'Gender';
$params['on_hold']['title'] = 'Primary Email On Hold';
$params['im']['title'] = 'Primary Instant Messanger';
$params['im_id']['title'] = 'Primary Instant Messanger ID';
}
$restore = CRM_Utils_Array::value('restore', $params) ? $params['restore'] : FALSE;
$skipUndelete = CRM_Utils_Array::value('skip_undelete', $params) ? $params['skip_undelete'] : FALSE;
+
+ // CRM-12929
+ // restrict permanent delete if a contact has financial trxn associated with it
+ $error = NULL;
+ if ($skipUndelete && CRM_Financial_BAO_FinancialItem::checkContactPresent(array($contactID), $error)) {
+ return civicrm_api3_create_error($error['_qf_default']);
+ }
if (CRM_Contact_BAO_Contact::deleteContact($contactID, $restore, $skipUndelete)) {
return civicrm_api3_create_success();
}
break;
}
+ // Fixme: This really needs to be handled at a lower level. @See CRM-13123
+ if (isset($params['preferred_communication_method'])) {
+ $params['preferred_communication_method'] = CRM_Utils_Array::implodePadded($params['preferred_communication_method']);
+ }
+
if (CRM_Utils_Array::value('contact_sub_type', $params) && CRM_Utils_Array::value('contact_type', $params)) {
if (!(CRM_Contact_BAO_ContactType::isExtendsContactType($params['contact_sub_type'], $params['contact_type']))) {
- return civicrm_api3_create_error("Invalid or Mismatched Contact SubType: " . implode(', ', (array)$params['contact_sub_type']));
+ throw new API_Exception("Invalid or Mismatched Contact SubType: " . implode(', ', (array)$params['contact_sub_type']));
}
}
* @static
*/
function _civicrm_api3_contact_update($params, $contactID = NULL) {
- $transaction = new CRM_Core_Transaction();
-
+ //@todo - doesn't contact create support 'id' which is already set- check & remove
if ($contactID) {
$params['contact_id'] = $contactID;
}
- $contact = CRM_Contact_BAO_Contact::create($params);
-
- $transaction->commit();
-
- return $contact;
+ return CRM_Contact_BAO_Contact::create($params);
}
/**
if ($customGreeting && $greetingId &&
($greetingId != array_search('Customized', $greetings))
) {
- return civicrm_api3_create_error(ts('Provide either %1 greeting id and/or %1 greeting or custom %1 greeting',
+ throw new API_Exception(ts('Provide either %1 greeting id and/or %1 greeting or custom %1 greeting',
array(1 => $key)
));
}
if ($greetingVal && $greetingId &&
($greetingId != CRM_Utils_Array::key($greetingVal, $greetings))
) {
- return civicrm_api3_create_error(ts('Mismatch in %1 greeting id and %1 greeting',
+ throw new API_Exception(ts('Mismatch in %1 greeting id and %1 greeting',
array(1 => $key)
));
}
if ($greetingId) {
if (!array_key_exists($greetingId, $greetings)) {
- return civicrm_api3_create_error(ts('Invalid %1 greeting Id', array(1 => $key)));
+ throw new API_Exception(ts('Invalid %1 greeting Id', array(1 => $key)));
}
if (!$customGreeting && ($greetingId == array_search('Customized', $greetings))) {
- return civicrm_api3_create_error(ts('Please provide a custom value for %1 greeting',
+ throw new API_Exception(ts('Please provide a custom value for %1 greeting',
array(1 => $key)
));
}
elseif ($greetingVal) {
if (!in_array($greetingVal, $greetings)) {
- return civicrm_api3_create_error(ts('Invalid %1 greeting', array(1 => $key)));
+ throw new API_Exception(ts('Invalid %1 greeting', array(1 => $key)));
}
$greetingId = CRM_Utils_Array::key($greetingVal, $greetings);
$greetingId = CRM_Utils_Array::key('Customized', $greetings);
}
- $customValue = $params['contact_id'] ? CRM_Core_DAO::getFieldValue('CRM_Contact_DAO_Contact',
- $params['contact_id'],
- "{$key}{$greeting}_custom"
- ) : FALSE;
+ $customValue = isset($params['contact_id']) ?
+ CRM_Core_DAO::getFieldValue(
+ 'CRM_Contact_DAO_Contact',
+ $params['contact_id'],
+ "{$key}{$greeting}_custom"
+ ) :
+ FALSE;
if (array_key_exists("{$key}{$greeting}_id", $params) && empty($params["{$key}{$greeting}_id"])) {
$nullValue = TRUE;
function civicrm_api3_contact_getquick($params) {
civicrm_api3_verify_mandatory($params, NULL, array('name'));
- $name = CRM_Utils_Array::value('name', $params);
+ $name = CRM_Utils_Type::escape($params['name'], 'String');
// get the autocomplete options from settings
$acpref = explode(CRM_Core_DAO::VALUE_SEPARATOR,
}
// If we are doing quicksearch by a field other than name, make sure that field is added to results
if (!empty($params['field_name'])) {
+ $field_name = CRM_Utils_String::munge($params['field_name']);
// Unique name contact_id = id
- if ($params['field_name'] == 'contact_id') {
- $params['field_name'] = 'id';
+ if ($field_name == 'contact_id') {
+ $field_name = 'id';
}
// phone_numeric should be phone
- $searchField = str_replace('_numeric', '', $params['field_name']);
+ $searchField = str_replace('_numeric', '', $field_name);
if(!in_array($searchField, $list)) {
$list[] = $searchField;
}
if ($value != 'id') {
$suffix = 'cc';
if (!empty($params['field_name']) && $params['field_name'] == 'value') {
- $suffix = CRM_Utils_Array::value('table_name', $params, 'cc');
+ $suffix = CRM_Utils_String::munge(CRM_Utils_Array::value('table_name', $params, 'cc'));
}
$actualSelectElements[] = $select[] = $suffix . '.' . $value;
}
$selectAliases = ", $selectAliases";
}
$from = implode(' ', $from);
- $limit = CRM_Utils_Array::value('limit', $params, 10);
+ $limit = (int) CRM_Utils_Array::value('limit', $params);
+ $limit = $limit > 0 ? $limit : 10;
// add acl clause here
list($aclFrom, $aclWhere) = CRM_Contact_BAO_Contact_Permission::cacheClause('cc');
$currEmpDetails = array();
if (CRM_Utils_Array::value('employee_id', $params)) {
if ($currentEmployer = CRM_Core_DAO::getFieldValue('CRM_Contact_DAO_Contact',
- CRM_Utils_Array::value('employee_id', $params),
+ (int) $params['employee_id'],
'employer_id'
)) {
if ($config->includeWildCardInName) {
//set default for current_employer or return contact with particular id
if (CRM_Utils_Array::value('id', $params)) {
- $where .= " AND cc.id = " .$params['id'];
+ $where .= " AND cc.id = " . (int) $params['id'];
}
if (CRM_Utils_Array::value('cid', $params)) {
- $where .= " AND cc.id <> {$params['cid']}";
+ $where .= " AND cc.id <> " . (int) $params['cid'];
}
//contact's based of relationhip type
//CRM-10687
if (!empty($params['field_name']) && !empty($params['table_name'])) {
- $field_name = $params['field_name'];
- $table_name = $params['table_name'];
+ $table_name = CRM_Utils_String::munge($params['table_name']);
$whereClause = " WHERE ( $table_name.$field_name LIKE '$strSearch')";
$exactWhereClause = " WHERE ( $table_name.$field_name = '$name')";
// Search by id should be exact
// send query to hook to be modified if needed
CRM_Utils_Hook::contactListQuery($query,
$name,
- CRM_Utils_Array::value('context', $params),
- CRM_Utils_Array::value('id', $params)
+ empty($params['context']) ? NULL : CRM_Utils_Type::escape($params['context'], 'String'),
+ empty($params['id']) ? NULL : $params['id']
);
$dao = CRM_Core_DAO::executeQuery($query);