Project

General

Profile

Paste
Download (7.21 KB) Statistics
| Branch: | Revision:

root / drupal7 / modules / aggregator / aggregator.api.php @ b0dc3a2e

1
<?php
2

    
3
/**
4
 * @file
5
 * Documentation for aggregator API.
6
 */
7

    
8
/**
9
 * @addtogroup hooks
10
 * @{
11
 */
12

    
13
/**
14
 * Create an alternative fetcher for aggregator.module.
15
 *
16
 * A fetcher downloads feed data to a Drupal site. The fetcher is called at the
17
 * first of the three aggregation stages: first, data is downloaded by the
18
 * active fetcher; second, it is converted to a common format by the active
19
 * parser; and finally, it is passed to all active processors, which manipulate
20
 * or store the data.
21
 *
22
 * Modules that define this hook can be set as the active fetcher within the
23
 * configuration page. Only one fetcher can be active at a time.
24
 *
25
 * @param $feed
26
 *   A feed object representing the resource to be downloaded. $feed->url
27
 *   contains the link to the feed. Download the data at the URL and expose it
28
 *   to other modules by attaching it to $feed->source_string.
29
 *
30
 * @return
31
 *   TRUE if fetching was successful, FALSE otherwise.
32
 *
33
 * @see hook_aggregator_fetch_info()
34
 * @see hook_aggregator_parse()
35
 * @see hook_aggregator_process()
36
 *
37
 * @ingroup aggregator
38
 */
39
function hook_aggregator_fetch($feed) {
40
  $feed->source_string = mymodule_fetch($feed->url);
41
}
42

    
43
/**
44
 * Specify the title and short description of your fetcher.
45
 *
46
 * The title and the description provided are shown within the configuration
47
 * page. Use as title the human readable name of the fetcher and as description
48
 * a brief (40 to 80 characters) explanation of the fetcher's functionality.
49
 *
50
 * This hook is only called if your module implements hook_aggregator_fetch().
51
 * If this hook is not implemented aggregator will use your module's file name
52
 * as title and there will be no description.
53
 *
54
 * @return
55
 *   An associative array defining a title and a description string.
56
 *
57
 * @see hook_aggregator_fetch()
58
 *
59
 * @ingroup aggregator
60
 */
61
function hook_aggregator_fetch_info() {
62
  return array(
63
    'title' => t('Default fetcher'),
64
    'description' => t('Default fetcher for resources available by URL.'),
65
  );
66
}
67

    
68
/**
69
 * Create an alternative parser for aggregator module.
70
 *
71
 * A parser converts feed item data to a common format. The parser is called
72
 * at the second of the three aggregation stages: first, data is downloaded
73
 * by the active fetcher; second, it is converted to a common format by the
74
 * active parser; and finally, it is passed to all active processors which
75
 * manipulate or store the data.
76
 *
77
 * Modules that define this hook can be set as the active parser within the
78
 * configuration page. Only one parser can be active at a time.
79
 *
80
 * @param $feed
81
 *   An object describing the resource to be parsed. $feed->source_string
82
 *   contains the raw feed data. The hook implementation should parse this data
83
 *   and add the following properties to the $feed object:
84
 *   - description: The human-readable description of the feed.
85
 *   - link: A full URL that directly relates to the feed.
86
 *   - image: An image URL used to display an image of the feed.
87
 *   - etag: An entity tag from the HTTP header used for cache validation to
88
 *     determine if the content has been changed.
89
 *   - modified: The UNIX timestamp when the feed was last modified.
90
 *   - items: An array of feed items. The common format for a single feed item
91
 *     is an associative array containing:
92
 *     - title: The human-readable title of the feed item.
93
 *     - description: The full body text of the item or a summary.
94
 *     - timestamp: The UNIX timestamp when the feed item was last published.
95
 *     - author: The author of the feed item.
96
 *     - guid: The global unique identifier (GUID) string that uniquely
97
 *       identifies the item. If not available, the link is used to identify
98
 *       the item.
99
 *     - link: A full URL to the individual feed item.
100
 *
101
 * @return
102
 *   TRUE if parsing was successful, FALSE otherwise.
103
 *
104
 * @see hook_aggregator_parse_info()
105
 * @see hook_aggregator_fetch()
106
 * @see hook_aggregator_process()
107
 *
108
 * @ingroup aggregator
109
 */
110
function hook_aggregator_parse($feed) {
111
  if ($items = mymodule_parse($feed->source_string)) {
112
    $feed->items = $items;
113
    return TRUE;
114
  }
115
  return FALSE;
116
}
117

    
118
/**
119
 * Specify the title and short description of your parser.
120
 *
121
 * The title and the description provided are shown within the configuration
122
 * page. Use as title the human readable name of the parser and as description
123
 * a brief (40 to 80 characters) explanation of the parser's functionality.
124
 *
125
 * This hook is only called if your module implements hook_aggregator_parse().
126
 * If this hook is not implemented aggregator will use your module's file name
127
 * as title and there will be no description.
128
 *
129
 * @return
130
 *   An associative array defining a title and a description string.
131
 *
132
 * @see hook_aggregator_parse()
133
 *
134
 * @ingroup aggregator
135
 */
136
function hook_aggregator_parse_info() {
137
  return array(
138
    'title' => t('Default parser'),
139
    'description' => t('Default parser for RSS, Atom and RDF feeds.'),
140
  );
141
}
142

    
143
/**
144
 * Create a processor for aggregator.module.
145
 *
146
 * A processor acts on parsed feed data. Active processors are called at the
147
 * third and last of the aggregation stages: first, data is downloaded by the
148
 * active fetcher; second, it is converted to a common format by the active
149
 * parser; and finally, it is passed to all active processors that manipulate or
150
 * store the data.
151
 *
152
 * Modules that define this hook can be activated as a processor within the
153
 * configuration page.
154
 *
155
 * @param $feed
156
 *   A feed object representing the resource to be processed. $feed->items
157
 *   contains an array of feed items downloaded and parsed at the parsing stage.
158
 *   See hook_aggregator_parse() for the basic format of a single item in the
159
 *   $feed->items array. For the exact format refer to the particular parser in
160
 *   use.
161
 *
162
 * @see hook_aggregator_process_info()
163
 * @see hook_aggregator_fetch()
164
 * @see hook_aggregator_parse()
165
 *
166
 * @ingroup aggregator
167
 */
168
function hook_aggregator_process($feed) {
169
  foreach ($feed->items as $item) {
170
    mymodule_save($item);
171
  }
172
}
173

    
174
/**
175
 * Specify the title and short description of your processor.
176
 *
177
 * The title and the description provided are shown within the configuration
178
 * page. Use as title the natural name of the processor and as description a
179
 * brief (40 to 80 characters) explanation of the functionality.
180
 *
181
 * This hook is only called if your module implements hook_aggregator_process().
182
 * If this hook is not implemented aggregator will use your module's file name
183
 * as title and there will be no description.
184
 *
185
 * @return
186
 *   An associative array defining a title and a description string.
187
 *
188
 * @see hook_aggregator_process()
189
 *
190
 * @ingroup aggregator
191
 */
192
function hook_aggregator_process_info() {
193
  return array(
194
    'title' => t('Default processor'),
195
    'description' => t('Creates lightweight records of feed items.'),
196
  );
197
}
198

    
199
/**
200
 * Remove stored feed data.
201
 *
202
 * Aggregator calls this hook if either a feed is deleted or a user clicks on
203
 * "remove items".
204
 *
205
 * If your module stores feed items for example on hook_aggregator_process() it
206
 * is recommended to implement this hook and to remove data related to $feed
207
 * when called.
208
 *
209
 * @param $feed
210
 *   The $feed object whose items are being removed.
211
 *
212
 * @ingroup aggregator
213
 */
214
function hook_aggregator_remove($feed) {
215
  mymodule_remove_items($feed->fid);
216
}
217

    
218
/**
219
 * @} End of "addtogroup hooks".
220
 */