CRM-12144 revert changes to prevent regression (keep the gremlins you know
authoreileen <eileen@fuzion.co.nz>
Mon, 18 Mar 2013 18:51:26 +0000 (07:51 +1300)
committereileen <eileen@fuzion.co.nz>
Mon, 18 Mar 2013 18:51:26 +0000 (07:51 +1300)
api/v3/Generic/Update.php

index 636a5cc5f9be1f4cb929212202a97ca64be0b79e..9975de71e57f12354c224f0226771a42cb97d9f2 100644 (file)
@@ -2,10 +2,14 @@
 // $Id$
 
 /**
- * Our original intention was not to have an update action. However, we wound up having
- * to retain it for backward compatibility. The only difference between update and create
- * is that update will throw an error if id is not a number
- * CRM-10908
+ * Update function is basically a hack to get around issues listed in
+ * http://issues.civicrm.org/jira/browse/CRM-12144
+ *
+ * It is not recommended & if update doesn't work & fix does then update will not be fixed
+ *
+ * To do this, perform a 'get' action to load the existing values, then merge in the updates
+ * and call 'create' to save the revised entity.
+ *
  * @param $apiRequest an array with keys:
  *  - entity: string
  *  - action: string
  *  - params: array, varies
  */
 function civicrm_api3_generic_update($apiRequest) {
+  $errorFnName = 'civicrm_api3_create_error';
 
-  if (!array_key_exists('id', $apiRequest['params']) ||
-      empty($apiRequest['params']['id']) ||
-      !is_numeric($apiRequest['params']['id'])) {
-    throw new api_Exception("Mandatory parameter missing `id`", 2000);
+  //$key_id = strtolower ($apiRequest['entity'])."_id";
+  $key_id = "id";
+  if (!array_key_exists($key_id, $apiRequest['params'])) {
+    return $errorFnName("Mandatory parameter missing $key_id");
   }
-  return civicrm_api($apiRequest['entity'], 'create', $apiRequest['params']);
+  $seek = array($key_id => $apiRequest['params'][$key_id], 'version' => $apiRequest['version']);
+  $existing = civicrm_api($apiRequest['entity'], 'get', $seek);
+  if ($existing['is_error']) {
+    return $existing;
+  }
+  if ($existing['count'] > 1) {
+    return $errorFnName("More than one " . $apiRequest['entity'] . " with id " . $apiRequest['params'][$key_id]);
+  }
+  if ($existing['count'] == 0) {
+    return $errorFnName("No " . $apiRequest['entity'] . " with id " . $apiRequest['params'][$key_id]);
+  }
+
+  $existing = array_pop($existing['values']);
+  $p = array_merge($existing, $apiRequest['params']);
+  return civicrm_api($apiRequest['entity'], 'create', $p);
 }