Projet

Général

Profil

Paste
Télécharger (2,93 ko) Statistiques
| Branche: | Révision:

root / drupal7 / sites / all / modules / ldap / ldap_feeds / FeedsLdapQueryFetcher.inc @ 91af538d

1
<?php
2

    
3
/**
4
 * @file
5
 * FeedsLdapQueryFetcher.
6
 */
7

    
8
/**
9
 * FeedsLdapQueryFetcherResult.
10
 */
11
class FeedsLdapQueryFetcherResult extends FeedsFetcherResult {
12
  public $query_ids = [];
13
  public $ldap_result;
14

    
15
  /**
16
   * Constructor.
17
   */
18
  public function __construct($source_config) {
19
    $this->query_ids = (isset($source_config['query_ids']) && is_array($source_config['query_ids'])) ? $source_config['query_ids'] : [];
20
    parent::__construct('');
21
    $this->ldap_result = $this->getRaw();
22
    return $this->ldap_result;
23
  }
24

    
25
  /**
26
   * Overrides parent::getRaw();.
27
   */
28
  public function getRaw() {
29

    
30
    $results = [];
31
    $count = 0;
32
    foreach ($this->query_ids as $i => $query_id) {
33
      $ldapQuery = ldap_query_get_queries($query_id, 'enabled', TRUE);
34
      $more_results = $ldapQuery->query();
35
      if (is_array($more_results)) {
36
        $count += $more_results['count'];
37
        $results = array_merge($results, $more_results);
38
      }
39
    }
40
    if ($count) {
41
      $results['count'] = $count;
42
    }
43
    return $results;
44
  }
45

    
46
}
47

    
48
/**
49
 * Fetches data via LDAP Query.
50
 */
51
class FeedsLdapQueryFetcher extends FeedsFetcher {
52

    
53
  /**
54
   * Implements FeedsFetcher::fetch().
55
   */
56
  public function fetch(FeedsSource $source) {
57
    $source_config = $source->getConfigFor($this);
58
    $result = new FeedsLdapQueryFetcherResult($source_config);
59
    return $result;
60
  }
61

    
62
  /**
63
   * Override parent::configDefaults().
64
   */
65
  public function configDefaults() {
66
    return [
67
      'query_ids' => [],
68
    ];
69
  }
70

    
71
  /**
72
   * Override parent::configForm().
73
   */
74
  public function configForm(&$form_state) {
75
    $queries = ldap_query_get_queries(NULL, 'enabled');
76
    $query_options = [0 => '--- select one or more queries ---'];
77
    foreach ($queries as $qid => $query) {
78
      $query_options[$qid] = $query->name;
79
    }
80
    $form = [];
81
    $form['query_ids'] = [
82
      '#type' => 'select',
83
      '#title' => t('LDAP Query'),
84
      '#multiple' => TRUE,
85
      '#size' => min(10, count($query_options)),
86
      '#required' => TRUE,
87
      '#default_value' => $this->config['query_ids'],
88
      '#description' => t('If more than one query is selected, results from all the queries will be returned.') .
89
      ' ' .
90
      t('Queries can be added and edited at !link', ['!link' => l(t('LDAP Query Admin'), LDAP_QUERY_INDEX_BASE_PATH)]),
91
      '#options' => $query_options,
92
    ];
93

    
94
    return $form;
95
  }
96

    
97
  /**
98
   * Override parent::sourceForm().
99
   */
100
  public function sourceForm($source_config) {
101

    
102
    $tokens = [
103
      '!edit_link' => l(t('Edit Feed'), 'admin/structure/feeds/' . $this->id),
104
    ];
105

    
106
    $form_state = [];
107
    $form = $this->configForm($form_state);
108
    $form['preamble'] = [
109
      '#type' => 'markup',
110
      '#markup' => t('This import is configured at !edit_link.', $tokens),
111
    ];
112

    
113
    return $form;
114
  }
115

    
116
  /**
117
   * Override parent::sourceFormValidate().
118
   */
119
  public function sourceFormValidate(&$values) {
120
    // Could execute query and see if it returns anything for validation.
121
  }
122

    
123
}