diff options
| author | Charles <sircharlesaze@gmail.com> | 2020-01-07 13:06:14 +0100 |
|---|---|---|
| committer | Charles <sircharlesaze@gmail.com> | 2020-01-07 13:06:14 +0100 |
| commit | 7086111ad4dd997e12a3220e1ee60c9b9bcf0bb8 (patch) | |
| tree | f7453d7dd5cbaaab246e23810b02d3edf1e451be /srcs/wordpress/wp-links-opml.php | |
| parent | c59bdcf77c50cbe89b4a93782cdd6d9e7532080e (diff) | |
| download | ft_server-7086111ad4dd997e12a3220e1ee60c9b9bcf0bb8.tar.gz ft_server-7086111ad4dd997e12a3220e1ee60c9b9bcf0bb8.tar.bz2 ft_server-7086111ad4dd997e12a3220e1ee60c9b9bcf0bb8.zip | |
Added wordpress
Diffstat (limited to 'srcs/wordpress/wp-links-opml.php')
| -rw-r--r-- | srcs/wordpress/wp-links-opml.php | 97 |
1 files changed, 97 insertions, 0 deletions
diff --git a/srcs/wordpress/wp-links-opml.php b/srcs/wordpress/wp-links-opml.php new file mode 100644 index 0000000..12d35b0 --- /dev/null +++ b/srcs/wordpress/wp-links-opml.php @@ -0,0 +1,97 @@ +<?php +/** + * Outputs the OPML XML format for getting the links defined in the link + * administration. This can be used to export links from one blog over to + * another. Links aren't exported by the WordPress export, so this file handles + * that. + * + * This file is not added by default to WordPress theme pages when outputting + * feed links. It will have to be added manually for browsers and users to pick + * up that this file exists. + * + * @package WordPress + */ + +require_once( dirname( __FILE__ ) . '/wp-load.php' ); + +header( 'Content-Type: text/xml; charset=' . get_option( 'blog_charset' ), true ); +$link_cat = ''; +if ( ! empty( $_GET['link_cat'] ) ) { + $link_cat = $_GET['link_cat']; + if ( ! in_array( $link_cat, array( 'all', '0' ) ) ) { + $link_cat = absint( (string) urldecode( $link_cat ) ); + } +} + +echo '<?xml version="1.0"?' . ">\n"; +?> +<opml version="1.0"> + <head> + <title> + <?php + /* translators: %s: Site title. */ + printf( __( 'Links for %s' ), esc_attr( get_bloginfo( 'name', 'display' ) ) ); + ?> + </title> + <dateCreated><?php echo gmdate( 'D, d M Y H:i:s' ); ?> GMT</dateCreated> + <?php + /** + * Fires in the OPML header. + * + * @since 3.0.0 + */ + do_action( 'opml_head' ); + ?> + </head> + <body> +<?php +if ( empty( $link_cat ) ) { + $cats = get_categories( + array( + 'taxonomy' => 'link_category', + 'hierarchical' => 0, + ) + ); +} else { + $cats = get_categories( + array( + 'taxonomy' => 'link_category', + 'hierarchical' => 0, + 'include' => $link_cat, + ) + ); +} + +foreach ( (array) $cats as $cat ) : + /** This filter is documented in wp-includes/bookmark-template.php */ + $catname = apply_filters( 'link_category', $cat->name ); + + ?> +<outline type="category" title="<?php echo esc_attr( $catname ); ?>"> + <?php + $bookmarks = get_bookmarks( array( 'category' => $cat->term_id ) ); + foreach ( (array) $bookmarks as $bookmark ) : + /** + * Filters the OPML outline link title text. + * + * @since 2.2.0 + * + * @param string $title The OPML outline title text. + */ + $title = apply_filters( 'link_title', $bookmark->link_name ); + ?> +<outline text="<?php echo esc_attr( $title ); ?>" type="link" xmlUrl="<?php echo esc_attr( $bookmark->link_rss ); ?>" htmlUrl="<?php echo esc_attr( $bookmark->link_url ); ?>" updated=" + <?php + if ( '0000-00-00 00:00:00' != $bookmark->link_updated ) { + echo $bookmark->link_updated;} + ?> +" /> + <?php + endforeach; // $bookmarks + ?> +</outline> + <?php +endforeach; // $cats +?> +</body> +</opml> |
