]> scripts.mit.edu Git - autoinstalls/wordpress.git/blob - wp-includes/default-filters.php
Wordpress 3.1.3
[autoinstalls/wordpress.git] / wp-includes / default-filters.php
1 <?php
2 /**
3  * Sets up the default filters and actions for most
4  * of the WordPress hooks.
5  *
6  * If you need to remove a default hook, this file will
7  * give you the priority for which to use to remove the
8  * hook.
9  *
10  * Not all of the default hooks are found in default-filters.php
11  *
12  * @package WordPress
13  */
14
15 // Strip, trim, kses, special chars for string saves
16 foreach ( array( 'pre_term_name', 'pre_comment_author_name', 'pre_link_name', 'pre_link_target', 'pre_link_rel', 'pre_user_display_name', 'pre_user_first_name', 'pre_user_last_name', 'pre_user_nickname' ) as $filter ) {
17         add_filter( $filter, 'sanitize_text_field'  );
18         add_filter( $filter, 'wp_filter_kses'       );
19         add_filter( $filter, '_wp_specialchars', 30 );
20 }
21
22 // Strip, kses, special chars for string display
23 foreach ( array( 'term_name', 'comment_author_name', 'link_name', 'link_target', 'link_rel', 'user_display_name', 'user_first_name', 'user_last_name', 'user_nickname' ) as $filter ) {
24         if ( is_admin() ) {
25                 // These are expensive. Run only on admin pages for defense in depth.
26                 add_filter( $filter, 'sanitize_text_field'  );
27                 add_filter( $filter, 'wp_kses_data'       );
28         }
29         add_filter( $filter, '_wp_specialchars', 30 );
30 }
31
32 // Kses only for textarea saves
33 foreach ( array( 'pre_term_description', 'pre_link_description', 'pre_link_notes', 'pre_user_description' ) as $filter ) {
34         add_filter( $filter, 'wp_filter_kses' );
35 }
36
37 // Kses only for textarea admin displays
38 if ( is_admin() ) {
39         foreach ( array( 'term_description', 'link_description', 'link_notes', 'user_description' ) as $filter ) {
40                 add_filter( $filter, 'wp_kses_data' );
41         }
42         add_filter( 'comment_text', 'wp_kses_post' );
43 }
44
45 // Email saves
46 foreach ( array( 'pre_comment_author_email', 'pre_user_email' ) as $filter ) {
47         add_filter( $filter, 'trim'           );
48         add_filter( $filter, 'sanitize_email' );
49         add_filter( $filter, 'wp_filter_kses' );
50 }
51
52 // Email admin display
53 foreach ( array( 'comment_author_email', 'user_email' ) as $filter ) {
54         add_filter( $filter, 'sanitize_email' );
55         if ( is_admin() )
56                 add_filter( $filter, 'wp_kses_data' );
57 }
58
59 // Save URL
60 foreach ( array( 'pre_comment_author_url', 'pre_user_url', 'pre_link_url', 'pre_link_image',
61         'pre_link_rss', 'pre_post_guid' ) as $filter ) {
62         add_filter( $filter, 'wp_strip_all_tags' );
63         add_filter( $filter, 'esc_url_raw'       );
64         add_filter( $filter, 'wp_filter_kses'    );
65 }
66
67 // Display URL
68 foreach ( array( 'user_url', 'link_url', 'link_image', 'link_rss', 'comment_url', 'post_guid' ) as $filter ) {
69         if ( is_admin() )
70                 add_filter( $filter, 'wp_strip_all_tags' );
71         add_filter( $filter, 'esc_url'           );
72         if ( is_admin() )
73                 add_filter( $filter, 'wp_kses_data'    );
74 }
75
76 // Slugs
77 foreach ( array( 'pre_term_slug' ) as $filter ) {
78         add_filter( $filter, 'sanitize_title' );
79 }
80
81 // Keys
82 foreach ( array( 'pre_post_type' ) as $filter ) {
83         add_filter( $filter, 'sanitize_user' );
84 }
85 foreach ( array( 'pre_post_status', 'pre_post_comment_status', 'pre_post_ping_status' ) as $filter ) {
86         add_filter( $filter, 'sanitize_key' );
87 }
88
89 // Mime types
90 add_filter( 'pre_post_mime_type', 'sanitize_mime_type' );
91 add_filter( 'post_mime_type', 'sanitize_mime_type' );
92
93 // Places to balance tags on input
94 foreach ( array( 'content_save_pre', 'excerpt_save_pre', 'comment_save_pre', 'pre_comment_content' ) as $filter ) {
95         add_filter( $filter, 'balanceTags', 50 );
96 }
97
98 // Format strings for display.
99 foreach ( array( 'comment_author', 'term_name', 'link_name', 'link_description', 'link_notes', 'bloginfo', 'wp_title', 'widget_title' ) as $filter ) {
100         add_filter( $filter, 'wptexturize'   );
101         add_filter( $filter, 'convert_chars' );
102         add_filter( $filter, 'esc_html'      );
103 }
104
105 // Format WordPress
106 foreach ( array( 'the_content', 'the_title' ) as $filter )
107         add_filter( $filter, 'capital_P_dangit', 11 );
108 add_filter( 'comment_text', 'capital_P_dangit', 31 );
109
110 // Format titles
111 foreach ( array( 'single_post_title', 'single_cat_title', 'single_tag_title', 'single_month_title', 'nav_menu_attr_title', 'nav_menu_description' ) as $filter ) {
112         add_filter( $filter, 'wptexturize' );
113         add_filter( $filter, 'strip_tags'  );
114 }
115
116 // Format text area for display.
117 foreach ( array( 'term_description' ) as $filter ) {
118         add_filter( $filter, 'wptexturize'      );
119         add_filter( $filter, 'convert_chars'    );
120         add_filter( $filter, 'wpautop'          );
121         add_filter( $filter, 'shortcode_unautop');
122 }
123
124 // Format for RSS
125 foreach ( array( 'term_name_rss' ) as $filter ) {
126         add_filter( $filter, 'convert_chars' );
127 }
128
129 // Pre save hierarchy
130 add_filter( 'wp_insert_post_parent', 'wp_check_post_hierarchy_for_loops', 10, 2 );
131 add_filter( 'wp_update_term_parent', 'wp_check_term_hierarchy_for_loops', 10, 3 );
132
133 // Display filters
134 add_filter( 'the_title', 'wptexturize'   );
135 add_filter( 'the_title', 'convert_chars' );
136 add_filter( 'the_title', 'trim'          );
137
138 add_filter( 'the_content', 'wptexturize'        );
139 add_filter( 'the_content', 'convert_smilies'    );
140 add_filter( 'the_content', 'convert_chars'      );
141 add_filter( 'the_content', 'wpautop'            );
142 add_filter( 'the_content', 'shortcode_unautop'  );
143 add_filter( 'the_content', 'prepend_attachment' );
144
145 add_filter( 'the_excerpt',     'wptexturize'      );
146 add_filter( 'the_excerpt',     'convert_smilies'  );
147 add_filter( 'the_excerpt',     'convert_chars'    );
148 add_filter( 'the_excerpt',     'wpautop'          );
149 add_filter( 'the_excerpt',     'shortcode_unautop');
150 add_filter( 'get_the_excerpt', 'wp_trim_excerpt'  );
151
152 add_filter( 'comment_text', 'wptexturize'            );
153 add_filter( 'comment_text', 'convert_chars'          );
154 add_filter( 'comment_text', 'make_clickable',      9 );
155 add_filter( 'comment_text', 'force_balance_tags', 25 );
156 add_filter( 'comment_text', 'convert_smilies',    20 );
157 add_filter( 'comment_text', 'wpautop',            30 );
158
159 add_filter( 'comment_excerpt', 'convert_chars' );
160
161 add_filter( 'list_cats',         'wptexturize' );
162
163 add_filter( 'wp_sprintf', 'wp_sprintf_l', 10, 2 );
164
165 // RSS filters
166 add_filter( 'the_title_rss',      'strip_tags'      );
167 add_filter( 'the_title_rss',      'ent2ncr',      8 );
168 add_filter( 'the_title_rss',      'esc_html'        );
169 add_filter( 'the_content_rss',    'ent2ncr',      8 );
170 add_filter( 'the_excerpt_rss',    'convert_chars'   );
171 add_filter( 'the_excerpt_rss',    'ent2ncr',      8 );
172 add_filter( 'comment_author_rss', 'ent2ncr',      8 );
173 add_filter( 'comment_text_rss',   'ent2ncr',      8 );
174 add_filter( 'comment_text_rss',   'esc_html'        );
175 add_filter( 'bloginfo_rss',       'ent2ncr',      8 );
176 add_filter( 'the_author',         'ent2ncr',      8 );
177
178 // Misc filters
179 add_filter( 'option_ping_sites',    'privacy_ping_filter'                 );
180 add_filter( 'option_blog_charset',  '_wp_specialchars'                    ); // IMPORTANT: This must not be wp_specialchars() or esc_html() or it'll cause an infinite loop
181 add_filter( 'option_home',          '_config_wp_home'                     );
182 add_filter( 'option_siteurl',       '_config_wp_siteurl'                  );
183 add_filter( 'tiny_mce_before_init', '_mce_set_direction'                  );
184 add_filter( 'pre_kses',             'wp_pre_kses_less_than'               );
185 add_filter( 'sanitize_title',       'sanitize_title_with_dashes'          );
186 add_action( 'check_comment_flood',  'check_comment_flood_db',       10, 3 );
187 add_filter( 'comment_flood_filter', 'wp_throttle_comment_flood',    10, 3 );
188 add_filter( 'pre_comment_content',  'wp_rel_nofollow',              15    );
189 add_filter( 'comment_email',        'antispambot'                         );
190 add_filter( 'option_tag_base',      '_wp_filter_taxonomy_base'            );
191 add_filter( 'option_category_base', '_wp_filter_taxonomy_base'            );
192 add_filter( 'the_posts',            '_close_comments_for_old_posts'       );
193 add_filter( 'comments_open',        '_close_comments_for_old_post', 10, 2 );
194 add_filter( 'pings_open',           '_close_comments_for_old_post', 10, 2 );
195 add_filter( 'editable_slug',        'urldecode'                           );
196 add_filter( 'nav_menu_meta_box_object', '_wp_nav_menu_meta_box_object'    );
197
198 // Atom SSL support
199 add_filter( 'atom_service_url','atom_service_url_filter' );
200
201 // Actions
202 add_action( 'wp_head',             'wp_enqueue_scripts',            1     );
203 add_action( 'wp_head',             'feed_links',                    2     );
204 add_action( 'wp_head',             'feed_links_extra',              3     );
205 add_action( 'wp_head',             'rsd_link'                             );
206 add_action( 'wp_head',             'wlwmanifest_link'                     );
207 add_action( 'wp_head',             'index_rel_link'                       );
208 add_action( 'wp_head',             'parent_post_rel_link',          10, 0 );
209 add_action( 'wp_head',             'start_post_rel_link',           10, 0 );
210 add_action( 'wp_head',             'adjacent_posts_rel_link_wp_head', 10, 0 );
211 add_action( 'wp_head',             'locale_stylesheet'                    );
212 add_action( 'publish_future_post', 'check_and_publish_future_post', 10, 1 );
213 add_action( 'wp_head',             'noindex',                       1     );
214 add_action( 'wp_head',             'wp_print_styles',               8     );
215 add_action( 'wp_head',             'wp_print_head_scripts',         9     );
216 add_action( 'wp_head',             'wp_generator'                         );
217 add_action( 'wp_head',             'rel_canonical'                        );
218 add_action( 'wp_footer',           'wp_print_footer_scripts'              );
219 add_action( 'wp_head',             'wp_shortlink_wp_head',          10, 0 );
220 add_action( 'template_redirect',   'wp_shortlink_header',           11, 0 );
221
222 // Login actions
223 add_action( 'login_head',          'wp_print_head_scripts',         9     );
224 add_action( 'login_footer',        'wp_print_footer_scripts'              );
225 add_action( 'login_init',          'send_frame_options_header',     10, 0 );
226
227 // Feed Generator Tags
228 foreach ( array( 'rss2_head', 'commentsrss2_head', 'rss_head', 'rdf_header', 'atom_head', 'comments_atom_head', 'opml_head', 'app_head' ) as $action ) {
229         add_action( $action, 'the_generator' );
230 }
231
232 // WP Cron
233 if ( !defined( 'DOING_CRON' ) )
234         add_action( 'sanitize_comment_cookies', 'wp_cron' );
235
236 // 2 Actions 2 Furious
237 add_action( 'do_feed_rdf',                'do_feed_rdf',             10, 1 );
238 add_action( 'do_feed_rss',                'do_feed_rss',             10, 1 );
239 add_action( 'do_feed_rss2',               'do_feed_rss2',            10, 1 );
240 add_action( 'do_feed_atom',               'do_feed_atom',            10, 1 );
241 add_action( 'do_pings',                   'do_all_pings',            10, 1 );
242 add_action( 'do_robots',                  'do_robots'                      );
243 add_action( 'sanitize_comment_cookies',   'sanitize_comment_cookies'       );
244 add_action( 'admin_print_scripts',        'print_head_scripts',      20    );
245 add_action( 'admin_print_footer_scripts', 'print_footer_scripts',    20    );
246 add_action( 'admin_print_styles',         'print_admin_styles',      20    );
247 add_action( 'init',                       'smilies_init',             5    );
248 add_action( 'plugins_loaded',             'wp_maybe_load_widgets',    0    );
249 add_action( 'plugins_loaded',             'wp_maybe_load_embeds',     0    );
250 add_action( 'shutdown',                   'wp_ob_end_flush_all',      1    );
251 add_action( 'pre_post_update',            'wp_save_post_revision'          );
252 add_action( 'publish_post',               '_publish_post_hook',       5, 1 );
253 add_action( 'save_post',                  '_save_post_hook',          5, 2 );
254 add_action( 'transition_post_status',     '_transition_post_status',  5, 3 );
255 add_action( 'comment_form', 'wp_comment_form_unfiltered_html_nonce'        );
256 add_action( 'wp_scheduled_delete',        'wp_scheduled_delete'            );
257 add_action( 'admin_init',                 'send_frame_options_header', 10, 0 );
258 add_action( 'importer_scheduled_cleanup', 'wp_delete_attachment'           );
259
260 // Navigation menu actions
261 add_action( 'delete_post',                '_wp_delete_post_menu_item'      );
262 add_action( 'delete_term',                '_wp_delete_tax_menu_item'       );
263 add_action( 'transition_post_status', '_wp_auto_add_pages_to_menu',  10, 3 );
264
265 // Post Thumbnail CSS class filtering
266 add_action( 'begin_fetch_post_thumbnail_html', '_wp_post_thumbnail_class_filter_add'    );
267 add_action( 'end_fetch_post_thumbnail_html',   '_wp_post_thumbnail_class_filter_remove' );
268
269 // Redirect Old Slugs
270 add_action( 'template_redirect', 'wp_old_slug_redirect'              );
271 add_action( 'post_updated',      'wp_check_for_changed_slugs', 12, 3 );
272
273 // Nonce check for Post Previews
274 add_action( 'init', '_show_post_preview' );
275
276 // Timezone
277 add_filter( 'pre_option_gmt_offset','wp_timezone_override_offset' );
278
279 // Admin Color Schemes
280 add_action( 'admin_init', 'register_admin_color_schemes', 1);
281 add_action( 'admin_color_scheme_picker', 'admin_color_scheme_picker' );
282
283 unset($filter, $action);
284
285 ?>