uid; $values['created'] = time(); $values['changed'] = time(); $values['title'] = ''; // The incoming values should have at a minimum the bundle_id; $bundle = $values['bundle']; $matches = array(); if (preg_match('/bio-data_(.*)/', $bundle, $matches)) { $term_id = $matches[1]; $values['type'] = 'TripalEntity'; $values['term_id'] = $term_id; } return parent::create($values); } /** * Delete a single entity. * * Really a convenience function for deleteMultiple(). */ public function delete($entity) { $transaction = db_transaction(); try { // Invoke hook_entity_delete(). module_invoke_all('entity_delete', $entity, $entity->type); field_attach_delete('TripalEntity', $entity); db_delete('tripal_entity') ->condition('id', $entity->id) ->execute(); } catch (Exception $e) { $transaction->rollback(); watchdog_exception('tripal_entities', $e); throw $e; return FALSE; } return TRUE; } /** * Sets the title for an entity. * * @param $entity * @param $title */ public function setTitle($entity, $title = NULL) { // If no title was supplied then we should try to generate one using the // default format set by admins. if (!$title) { // First get the format for the title based on the bundle of the entity. $bundle_entity = tripal_bundle_load($entity->bundle); $title = tripal_get_title_format($bundle_entity); // Determine which tokens were used in the format string if (preg_match_all('/\[\w+\.\w+\]/', $title, $matches)) { $used_tokens = $matches[0]; foreach($used_tokens as $token) { $field = str_replace(array('.','[',']'),array('__','',''),$token); $value = ''; if (isset($entity->{$field})) { // Render the value from the field. // @TODO: Handle the case where thefield is empty... currently returns error. $field_value = field_get_items('TripalEntity', $entity, $field); $field_render_arr = field_view_value('TripalEntity', $entity, $field, $field_value[0]); $value = render($field_render_arr); } $title = str_replace($token, $value, $title); } } } // As long as we were able to determine a title, we should update it ;-). if ($title) { db_update('tripal_entity') ->fields(array( 'title' => $title )) ->condition('id', $entity->id) ->execute(); } } /** * Saves the custom fields using drupal_write_record(). */ public function save($entity) { global $user; $pkeys = array(); $transaction = db_transaction(); try { // If our entity has no id, then we need to give it a // time of creation. if (empty($entity->id)) { $entity->created = time(); $invocation = 'entity_insert'; } else { $invocation = 'entity_update'; $pkeys = array('id'); } // Invoke hook_entity_presave(). module_invoke_all('entity_presave', $entity, $entity->type); // Write out the entity record. $record = array( 'term_id' => $entity->term_id, 'type' => $entity->type, 'bundle' => $entity->bundle, 'title' => $entity->title, 'uid' => $user->uid, 'created' => $entity->created, 'changed' => time(), ); if ($invocation == 'entity_update') { $record['id'] = $entity->id; } $success = drupal_write_record('tripal_entity', $record, $pkeys); if ($success == SAVED_NEW) { $entity->id = $record['id']; } // Now we need to either insert or update the fields which are // attached to this entity. We use the same primary_keys logic // to determine whether to update or insert, and which hook we // need to invoke. if ($invocation == 'entity_insert') { field_attach_insert('TripalEntity', $entity); } else { field_attach_update('TripalEntity', $entity); } // Invoke either hook_entity_update() or hook_entity_insert(). module_invoke_all('entity_postsave', $entity, $entity->type); module_invoke_all($invocation, $entity, $entity->type); return $entity; } catch (Exception $e) { $transaction->rollback(); watchdog_exception('tripal_core', $e); drupal_set_message("Could not save the entity:" . $e->getMessage(), "error"); return FALSE; } } }