vocabulary(); $term = new stdClass(); $term->vid = $vocabulary->vid; $term->vocabulary_machine_name = $vocabulary->machine_name; return $term; } /** * Loads an existing term. */ protected function entityLoad(FeedsSource $source, $tid) { return taxonomy_term_load($tid); } /** * Validates a term. */ protected function entityValidate($term) { if (empty($term->name)) { throw new FeedsValidationException(t('Term name missing.')); } } /** * Saves a term. */ protected function entitySave($term) { taxonomy_term_save($term); } /** * Deletes a series of terms. */ protected function entityDeleteMultiple($tids) { foreach ($tids as $tid) { taxonomy_term_delete($tid); } } /** * Override parent::configDefaults(). */ public function configDefaults() { return array( 'vocabulary' => 0, ) + parent::configDefaults(); } /** * Override parent::configForm(). */ public function configForm(&$form_state) { $options = array(0 => t('Select a vocabulary')); foreach (taxonomy_get_vocabularies() as $vocab) { $options[$vocab->machine_name] = check_plain($vocab->name); } $form = parent::configForm($form_state); $form['vocabulary'] = array( '#type' => 'select', '#title' => t('Import to vocabulary'), '#description' => t('Choose the vocabulary to import into. CAUTION: when deleting terms through the "Delete items" tab, Feeds will delete all terms from this vocabulary.'), '#options' => $options, '#default_value' => $this->config['vocabulary'], ); return $form; } /** * Override parent::configFormValidate(). */ public function configFormValidate(&$values) { if (empty($values['vocabulary'])) { form_set_error('vocabulary', t('Choose a vocabulary')); } } /** * Return available mapping targets. */ public function getMappingTargets() { $targets = parent::getMappingTargets(); $targets += array( 'name' => array( 'name' => t('Term name'), 'description' => t('Name of the taxonomy term.'), 'optional_unique' => TRUE, ), 'description' => array( 'name' => t('Term description'), 'description' => t('Description of the taxonomy term.'), ), ); // Let implementers of hook_feeds_term_processor_targets() add their targets. try { self::loadMappers(); feeds_alter('feeds_processor_targets', $targets, 'taxonomy_term', $this->vocabulary()->machine_name); } catch (Exception $e) {} return $targets; } /** * Get id of an existing feed item term if available. */ protected function existingEntityId(FeedsSource $source, FeedsParserResult $result) { if ($tid = parent::existingEntityId($source, $result)) { return $tid; } // The only possible unique target is name. foreach ($this->uniqueTargets($source, $result) as $target => $value) { if ($target == 'name') { $vocabulary = $this->vocabulary(); if ($tid = db_query("SELECT tid FROM {taxonomy_term_data} WHERE name = :name AND vid = :vid", array(':name' => $value, ':vid' => $vocabulary->vid))->fetchField()) { return $tid; } } } return 0; } /** * Return vocabulary to map to. */ public function vocabulary() { if (isset($this->config['vocabulary'])) { if ($vocabulary = taxonomy_vocabulary_machine_name_load($this->config['vocabulary'])) { return $vocabulary; } } throw new Exception(t('No vocabulary defined for Taxonomy Term processor.')); } }