Do not look contact in buildForm hook when there is no logged in user.
[org.fsf.memberdashboard.git] / memberdashboard.php
index e650b1b9e16e972cf595ae18ed9f1f129c240618..8f969f1a05fd810f4636a2c39e1099e3c9f91049 100644 (file)
@@ -121,45 +121,58 @@ function memberdashboard_civicrm_post($op, $objectName, $objectId, &$objectRef)
   $triggerOps = array('create', 'edit', 'delete');
 
   if($objectName == 'Membership' && in_array($op, $triggerOps)) {
-    // TODO: Extract all of this to a class for clarity and
-    // organization's sake.
-
-    // Get the oldest join date for the contact's memberships.
-    $contactId = $objectRef->contact_id;
-    $dao = CRM_Core_DAO::executeQuery(
-      'SELECT join_date FROM civicrm_membership WHERE contact_id=%1 ORDER BY join_date ASC LIMIT 1',
-      array( 1 => array($contactId, 'Integer') )
-    );
-
-    if($dao->fetch()) {
-      // Make the API call.
-      $joinDate = $dao->join_date;
-      $apiUrl = civicrm_api3('setting', 'getvalue', array(
-        'name' => 'memberdashboard_button_api_url',
-        'group' => MEMBERDASHBOARD_SETTINGS_GROUP
-      ));
-      $user = civicrm_api3('setting', 'getvalue', array(
-        'name' => 'memberdashboard_button_api_user',
-        'group' => MEMBERDASHBOARD_SETTINGS_GROUP
-      ));
-      $password = civicrm_api3('setting', 'getvalue', array(
-        'name' => 'memberdashboard_button_api_password',
-        'group' => MEMBERDASHBOARD_SETTINGS_GROUP
-      ));
-      $params = http_build_query(array(
-        'contact_id' => $contactId,
-        'date' => $joinDate
-      ));
-
-      if(!empty($apiUrl) && !empty($user) && !empty($password)) {
-        $curl = curl_init();
-        curl_setopt($curl, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);
-        curl_setopt($curl, CURLOPT_USERPWD, "$user:$password");
-        curl_setopt($curl, CURLOPT_URL, "$apiUrl?$params");
-        curl_exec($curl);
+    try {
+      // TODO: Extract all of this to a class for clarity and
+      // organization's sake.
+
+      // Get the oldest join date for the contact's memberships.
+      $contactId = $objectRef->contact_id;
+      $dao = CRM_Core_DAO::executeQuery(
+        'SELECT join_date FROM civicrm_membership WHERE contact_id=%1 ORDER BY join_date ASC LIMIT 1',
+        array( 1 => array($contactId, 'Integer') )
+      );
+
+      if($dao->fetch()) {
+        // Make the API call.
+        $joinDate = $dao->join_date;
+        $apiUrl = civicrm_api3('setting', 'getvalue', array(
+          'name' => 'memberdashboard_button_api_url',
+          'group' => MEMBERDASHBOARD_SETTINGS_GROUP
+        ));
+        $user = civicrm_api3('setting', 'getvalue', array(
+          'name' => 'memberdashboard_button_api_user',
+          'group' => MEMBERDASHBOARD_SETTINGS_GROUP
+        ));
+        $password = civicrm_api3('setting', 'getvalue', array(
+          'name' => 'memberdashboard_button_api_password',
+          'group' => MEMBERDASHBOARD_SETTINGS_GROUP
+        ));
+
+        if(!empty($apiUrl) && !empty($user) && !empty($password)) {
+          $url = "$apiUrl?contact_id=" . $contactId . "&date=" . $joinDate;
+          $curl = curl_init();
+          curl_setopt($curl, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);
+          curl_setopt($curl, CURLOPT_USERPWD, "$user:$password");
+          curl_setopt($curl, CURLOPT_URL, $url);
+          curl_exec($curl);
+        }
       }
+
+      $dao->free();
+    } catch(Exception $e) {
+      // Ignore it.  Not the end of the world if this fails.
     }
+  }
+}
 
-    $dao->free();
+function memberdashboard_civicrm_buildForm($formName, &$form) {
+  // Hack to fix state select box in 4.4.x
+  if($formName == 'CRM_Profile_Form_Edit') {
+    $contactId = CRM_Core_Session::singleton()->get('userID');
+    if($concactId) {
+      $contact = civicrm_api3('contact', 'getsingle', array( 'id' => $contactId ));
+      $defaults['state_province-Primary'] = $contact['state_province_id'];
+      $form->setDefaults($defaults);
+    }
   }
 }