| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257 | <?php/** * @file * FeedsTermProcessor class. *//** * Feeds processor plugin. Create taxonomy terms from feed items. */class FeedsTermProcessor extends FeedsProcessor {  /**   * Define entity type.   */  public function entityType() {    return 'taxonomy_term';  }  /**   * Implements parent::entityInfo().   */  protected function entityInfo() {    $info = parent::entityInfo();    $info['label plural'] = t('Terms');    $info['bundle name'] = t('Vocabulary');    return $info;  }  /**   * Creates a new term in memory and returns it.   */  protected function newEntity(FeedsSource $source) {    $vocabulary = $this->vocabulary();    $term = parent::newEntity($source);    $term->vid = $vocabulary->vid;    $term->vocabulary_machine_name = $vocabulary->machine_name;    return $term;  }  /**   * Load an existing entity.   */  protected function entityLoad(FeedsSource $source, $entity_id) {    $entity = parent::entityLoad($source, $entity_id);    // Avoid missing bundle errors when term has been loaded directly from db.    if (empty($entity->vocabulary_machine_name) && !empty($entity->vid)) {      $vocabulary = taxonomy_vocabulary_load($entity->vid);      $entity->vocabulary_machine_name = ($vocabulary) ? $vocabulary->machine_name : NULL;    }    return $entity;  }  /**   * Validates a term.   */  protected function entityValidate($term) {    parent::entityValidate($term);    if (drupal_strlen($term->name) == 0) {      throw new FeedsValidationException(t('Term name missing.'));    }  }  /**   * Saves a term.   *   * We de-array parent fields with only one item.   * This stops leftandright module from freaking out.   */  protected function entitySave($term) {    if (isset($term->parent)) {      if (is_array($term->parent) && count($term->parent) == 1) {        $term->parent = reset($term->parent);      }      if (isset($term->tid) && ($term->parent == $term->tid || (is_array($term->parent) && in_array($term->tid, $term->parent)))) {        throw new FeedsValidationException(t("A term can't be its own child. GUID:@guid", array('@guid' => $term->feeds_item->guid)));      }    }    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();  }  /**   * Overrides parent::setTargetElement().   *   * Operate on a target item that is a taxonomy term.   */  public function setTargetElement(FeedsSource $source, $target_term, $target_element, $value, array $mapping = array()) {    switch ($target_element) {      case 'parent':        if (!empty($value)) {          $terms = taxonomy_get_term_by_name($value);          $parent_tid = '';          foreach ($terms as $term) {            if ($term->vid == $target_term->vid) {              $parent_tid = $term->tid;            }          }          if (!empty($parent_tid)) {            $target_term->parent[] = $parent_tid;          }          else {            $target_term->parent[] = 0;          }        }        else {          $target_term->parent[] = 0;        }        break;      case 'parentguid':        // value is parent_guid field value        $parent_tid = 0;        $query = db_select('feeds_item')          ->fields('feeds_item', array('entity_id'))          ->condition('entity_type', $this->entityType());        $term_ids = array_keys($query->condition('guid', $value)->execute()->fetchAllAssoc('entity_id'));        if (!empty($term_ids)) {          $terms = entity_load($this->entityType(), $term_ids);          foreach ($terms as $term) {            if ($term->vid == $target_term->vid) {              $parent_tid = $term->tid;              break;            }          }        }        $target_term->parent[] = $parent_tid;        break;      case 'weight':        if (!empty($value)) {          $weight = intval($value);        }        else {          $weight = 0;        }        $target_term->weight = $weight;        break;      case 'description':        if (!empty($mapping['format'])) {          $target_term->format = $mapping['format'];        }        elseif (!empty($this->config['input_format'])) {          $target_term->format = $this->config['input_format'];        }        else {          $target_term->format = filter_fallback_format();        }        $target_term->description = $value;        break;      default:        parent::setTargetElement($source, $target_term, $target_element, $value);        break;    }  }  /**   * 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,      ),      'parent' => array(        'name' => t('Parent: Term name'),        'description' => t('The name of the parent taxonomy term.'),        'optional_unique' => TRUE,      ),      'parentguid' => array(        'name' => t('Parent: GUID'),        'description' => t('The GUID of the parent taxonomy term.'),        'optional_unique' => TRUE,      ),      'weight' => array(        'name' => t('Term weight'),        'description' => t('Weight of the taxonomy term.'),        'optional_unique' => TRUE,      ),      'description' => array(        'name' => t('Term description'),        'description' => t('Description of the taxonomy term.'),        'summary_callbacks' => array('text_feeds_summary_callback'),        'form_callbacks' => array('text_feeds_form_callback'),      ),    );    $this->getHookTargets($targets);    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 ($vocabulary = taxonomy_vocabulary_machine_name_load($this->bundle())) {      return $vocabulary;    }    throw new Exception(t('No vocabulary defined for Taxonomy Term processor.'));  }  /**   * Overrides FeedsProcessor::dependencies().   */  public function dependencies() {    $dependencies = parent::dependencies();    $dependencies['taxonomy'] = 'taxonomy';    return $dependencies;  }}
 |