2016-06-28 15:11:52 +01:00
|
|
|
|
<?php
|
|
|
|
|
/*
|
2016-07-21 16:12:13 +01:00
|
|
|
|
Plugin Name: WP Flat Export
|
2016-06-28 15:11:52 +01:00
|
|
|
|
Plugin URI: https://github.com/petermolnar/wp-flatexport
|
2016-07-21 16:12:13 +01:00
|
|
|
|
Description: auto-export WordPress flat, structured, readable plain text
|
|
|
|
|
Version: 0.4
|
|
|
|
|
Author: Peter Molnar <hello@petermolnar.net>
|
|
|
|
|
Author URI: http://petermolnar.net/
|
2016-06-28 15:11:52 +01:00
|
|
|
|
License: GPLv3
|
|
|
|
|
*/
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
/* Copyright 2015-2016 Peter Molnar ( hello@petermolnar.net )
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
|
it under the terms of the GNU General Public License, version 3, as
|
|
|
|
|
published by the Free Software Foundation.
|
|
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
|
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
|
*/
|
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
namespace WP_FLATEXPORTS;
|
|
|
|
|
|
2016-07-14 10:27:06 +01:00
|
|
|
|
define ( 'force', true );
|
2016-06-28 15:27:02 +01:00
|
|
|
|
define ( 'basedir', 'flat' );
|
2016-07-21 16:12:13 +01:00
|
|
|
|
define ( 'basefile', 'index.txt' );
|
2016-06-28 15:27:02 +01:00
|
|
|
|
define ( 'maxattachments', 100 );
|
2016-07-14 16:21:26 +01:00
|
|
|
|
define ( 'expire', 10 );
|
2016-07-21 16:12:13 +01:00
|
|
|
|
define ( 'wrap', 80 );
|
2016-06-28 15:27:02 +01:00
|
|
|
|
|
|
|
|
|
\register_activation_hook( __FILE__ , '\WP_FLATEXPORTS\plugin_activate' );
|
2016-07-21 16:12:13 +01:00
|
|
|
|
\add_action( 'wp', '\WP_FLATEXPORTS\export' );
|
2016-07-14 16:21:26 +01:00
|
|
|
|
\add_action ( 'init', '\WP_FLATEXPORTS\init' );
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* activate hook
|
|
|
|
|
*/
|
|
|
|
|
function plugin_activate() {
|
|
|
|
|
if ( version_compare( phpversion(), 5.4, '<' ) ) {
|
|
|
|
|
die( 'The minimum PHP version required for this plugin is 5.3' );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2016-07-14 16:21:26 +01:00
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function init () {
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$filters = array (
|
|
|
|
|
'wp_flatexport_post' => array (
|
|
|
|
|
'insert_title',
|
|
|
|
|
'insert_excerpt',
|
|
|
|
|
'insert_content',
|
|
|
|
|
'insert_published',
|
|
|
|
|
'insert_urls',
|
|
|
|
|
'insert_author',
|
|
|
|
|
'insert_tags',
|
|
|
|
|
'insert_location',
|
|
|
|
|
'insert_uuid',
|
|
|
|
|
),
|
|
|
|
|
'wp_flatexport_content' => array (
|
|
|
|
|
'post_content_resized2orig',
|
|
|
|
|
'post_content_clean_uploaddir',
|
|
|
|
|
'post_content_insert_featured',
|
|
|
|
|
'post_content_clear_imgids',
|
|
|
|
|
'post_content_url2footnote',
|
|
|
|
|
'post_content_headers',
|
|
|
|
|
//'post_content_wordwrap',
|
|
|
|
|
//'post_content_urls',
|
|
|
|
|
),
|
|
|
|
|
'wp_flatexport_comment' => array (
|
|
|
|
|
'comment_insert_type',
|
|
|
|
|
'comment_insert_content',
|
|
|
|
|
'comment_insert_from',
|
|
|
|
|
'comment_insert_at',
|
|
|
|
|
),
|
|
|
|
|
);
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
foreach ( $filters as $for => $subfilters ) {
|
|
|
|
|
foreach ( $subfilters as $k => $filter ) {
|
|
|
|
|
\add_filter (
|
|
|
|
|
$for,
|
|
|
|
|
"\\WP_FLATEXPORTS\\{$filter}",
|
|
|
|
|
10 * ( $k + 1 ),
|
|
|
|
|
2
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
}
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
}
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
function depthmap () {
|
|
|
|
|
|
|
|
|
|
return array (
|
|
|
|
|
1 => "=", // asciidoc, restuctured text, and markdown compatible
|
|
|
|
|
2 => "-", // asciidoc, restuctured text, and markdown compatible
|
|
|
|
|
3 => "~", // asciidoc only
|
|
|
|
|
4 => "^", // asciidoc only
|
|
|
|
|
5 => "+", // asciidoc only
|
|
|
|
|
);
|
|
|
|
|
}
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function _insert_head ( $title, $depth = 2 ) {
|
|
|
|
|
$map = depthmap();
|
|
|
|
|
$underline = str_repeat( $map[ $depth ], mb_strlen( $title) );
|
|
|
|
|
return "\n\n{$title}\n${underline}\n";
|
2016-07-14 16:21:26 +01:00
|
|
|
|
}
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
/**
|
|
|
|
|
* extends the $text with
|
|
|
|
|
*
|
|
|
|
|
* (post title)
|
|
|
|
|
* ============
|
|
|
|
|
*
|
|
|
|
|
*/
|
2016-07-14 16:21:26 +01:00
|
|
|
|
function insert_title ( $text, $post ) {
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$title = trim( \get_the_title( $post->ID ) );
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
if ( empty( $title ) )
|
2016-07-14 16:21:26 +01:00
|
|
|
|
return $text;
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
// the linebreaks are here in case the order of inserting things is changed
|
|
|
|
|
$text .= _insert_head( $title, 1 );
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
|
|
|
|
return $text;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* extends the $text with
|
|
|
|
|
*
|
|
|
|
|
* UUID
|
|
|
|
|
* ----
|
|
|
|
|
* (post UUID)
|
|
|
|
|
*
|
|
|
|
|
* post UUID is an md5 hash of:
|
|
|
|
|
* post ID + (math add) epoch of post first publish date
|
|
|
|
|
* this should not ever change!
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function insert_uuid ( $text, $post ) {
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$uuid = hash (
|
|
|
|
|
'md5',
|
|
|
|
|
(int)$post->ID + (int) get_post_time('U', true, $post->ID )
|
|
|
|
|
);
|
|
|
|
|
$text .= _insert_head( "UUID" );
|
|
|
|
|
$text .= "{$uuid}";
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
|
|
|
|
return $text;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* extends the $text with
|
|
|
|
|
*
|
|
|
|
|
* \n\n (post excerpt)
|
|
|
|
|
*/
|
|
|
|
|
function insert_excerpt ( $text, $post ) {
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$excerpt = trim( $post->post_excerpt );
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
if( ! empty( $excerpt ) )
|
|
|
|
|
$text .= "\n\n" . $excerpt;
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
|
|
|
|
return $text;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* extends the $text with
|
|
|
|
|
*
|
|
|
|
|
* \n\n (post content)
|
|
|
|
|
*/
|
|
|
|
|
function insert_content ( $text, $post ) {
|
|
|
|
|
$content = apply_filters(
|
|
|
|
|
'wp_flatexport_content',
|
|
|
|
|
trim( $post->post_content ),
|
|
|
|
|
$post
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
if ( ! empty( $content ) )
|
|
|
|
|
$text .= "\n\n" . $content;
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
return $text;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* extends the $text with
|
|
|
|
|
*
|
|
|
|
|
* Published
|
|
|
|
|
* ---------
|
|
|
|
|
* initial - (post publish date in Y-m-d H:i:s P format)
|
|
|
|
|
* [current - (post last update date in Y-m-d H:i:s P format)]
|
|
|
|
|
*/
|
2016-07-14 16:21:26 +01:00
|
|
|
|
function insert_published ( $text, $post ) {
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$published = \get_the_time( 'Y-m-d H:i:s P', $post->ID );
|
|
|
|
|
$modified = \get_the_modified_time( 'Y-m-d H:i:s P', $post->ID );
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$text .= _insert_head ( "Published" );
|
|
|
|
|
$text .= "initial - {$published}";
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
if ( $published != $modified )
|
|
|
|
|
$text .= "\ncurrent - {$modified}";
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
|
|
|
|
return $text;
|
|
|
|
|
}
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* extends the $text with
|
|
|
|
|
*
|
|
|
|
|
* URLs
|
|
|
|
|
* ----
|
|
|
|
|
* - http://site.com/post_ID
|
|
|
|
|
* - (post shortlink)
|
|
|
|
|
* - (post permalink)
|
|
|
|
|
* [- additional urls, one per line]
|
|
|
|
|
*/
|
2016-07-14 16:21:26 +01:00
|
|
|
|
function insert_urls ( $text, $post ) {
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
// basic ones
|
|
|
|
|
$slugs = \get_post_meta ( $post->ID, '_wp_old_slug' );
|
|
|
|
|
array_push ( $slugs, $post->post_name );
|
|
|
|
|
array_push ( $slugs, $post->ID );
|
|
|
|
|
|
|
|
|
|
// eliminate revisions
|
|
|
|
|
foreach ( $slugs as $k => $slug ) {
|
|
|
|
|
if ( preg_match ( '/-revision-v[0-9]+/', $slug ) ) {
|
|
|
|
|
unset ( $slugs[ $k ] );
|
|
|
|
|
continue;
|
|
|
|
|
}
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
// make them real URLs
|
|
|
|
|
// site_url does not allow numbers only as slugs, so we're doing it the
|
|
|
|
|
// hard way
|
|
|
|
|
$slugs[ $k ] = rtrim ( \site_url( ), '/' ) . '/' . $slug;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// just in case these differ
|
|
|
|
|
array_push ( $slugs, \get_permalink( $post ) );
|
|
|
|
|
array_push ( $slugs, \wp_get_shortlink( $post->ID ) );
|
|
|
|
|
|
|
|
|
|
// get syndicated URLs
|
|
|
|
|
$syndications = \get_post_meta ( $post->ID, 'syndication_urls', true );
|
|
|
|
|
if ( ! empty( $syndications ) )
|
|
|
|
|
$slugs = array_merge( $slugs, explode( "\n", trim( $syndications ) ) );
|
|
|
|
|
|
|
|
|
|
// get rid of trailing slashes; it's either no trailing slash or slash on
|
|
|
|
|
// everything, which breaks .html-like real document path URLs
|
|
|
|
|
foreach ( $slugs as $k => $slug ) {
|
|
|
|
|
$slugs[ $k ] = rtrim( $slug, '/' );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// eliminate duplicates
|
|
|
|
|
$slugs = array_unique ( $slugs );
|
|
|
|
|
|
|
|
|
|
// make it more readable
|
|
|
|
|
usort(
|
|
|
|
|
$slugs,
|
|
|
|
|
function ( $a, $b ) {
|
|
|
|
|
return strlen( $a ) - strlen( $b );
|
|
|
|
|
}
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
$text .= _insert_head ( "URLs" );
|
|
|
|
|
$text .= "- " . join ( "\n- ", $slugs );
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
|
|
|
|
return $text;
|
|
|
|
|
}
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* extends the $text with
|
|
|
|
|
*
|
|
|
|
|
* Author
|
|
|
|
|
* ------
|
|
|
|
|
* Author Display Name [<author@email>]
|
|
|
|
|
* avatar URL
|
|
|
|
|
* [ author URL ]
|
|
|
|
|
*/
|
2016-07-14 16:21:26 +01:00
|
|
|
|
function insert_author ( $text, $post ) {
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$author_id = $post->post_author;
|
|
|
|
|
$author = \get_the_author_meta ( 'display_name' , $author_id );
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
if ( empty( $author ) )
|
2016-07-14 16:21:26 +01:00
|
|
|
|
return $text;
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
if ( $author_email = \get_the_author_meta ( 'email' , $author_id ) )
|
|
|
|
|
$author .= " <{$author_email}>";
|
|
|
|
|
|
|
|
|
|
$thid = get_user_option ( 'metronet_image_id', $author_id );
|
|
|
|
|
if ( $thid ) {
|
|
|
|
|
$image = wp_get_attachment_image_src ( $thid, 'thumbnail' );
|
|
|
|
|
$avatar = \site_url( $image[0]);
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
$avatar = gravatar ( $author_email );
|
|
|
|
|
}
|
|
|
|
|
$author .= "\n${avatar}";
|
|
|
|
|
|
|
|
|
|
if ( $author_url = \get_the_author_meta ( 'url' , $author_id ) )
|
|
|
|
|
$author .= " \n{$author_url}";
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$text .= _insert_head ( "Author" );
|
|
|
|
|
$text .= "{$author}";
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
|
|
|
|
return $text;
|
|
|
|
|
}
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* extends the $text with
|
|
|
|
|
*
|
|
|
|
|
* Tags
|
|
|
|
|
* ----
|
|
|
|
|
* \#(comma separated list of # tags)
|
|
|
|
|
*/
|
2016-07-14 16:21:26 +01:00
|
|
|
|
function insert_tags ( $text, $post ) {
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$raw_tags = \wp_get_post_terms( $post->ID, 'post_tag' );
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
if ( empty( $raw_tags ) )
|
2016-07-14 16:21:26 +01:00
|
|
|
|
return $text;
|
|
|
|
|
|
|
|
|
|
$tags = array();
|
2016-07-21 16:12:13 +01:00
|
|
|
|
foreach ( $raw_tags as $k => $tag ) {
|
2016-07-14 16:21:26 +01:00
|
|
|
|
array_push( $tags, "#{$tag->name}" );
|
|
|
|
|
}
|
2016-07-21 16:12:13 +01:00
|
|
|
|
|
|
|
|
|
array_unique( $tags );
|
|
|
|
|
$tags = join ( ', ', $tags );
|
|
|
|
|
|
|
|
|
|
$text .= _insert_head ( "Tags" );
|
2016-07-14 16:21:26 +01:00
|
|
|
|
// these are hashtags, so escape the first one to avoid converting it into
|
|
|
|
|
// a header
|
|
|
|
|
$text .= "\\" . $tags;
|
|
|
|
|
|
|
|
|
|
return $text;
|
|
|
|
|
}
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* extends the $text with
|
|
|
|
|
*
|
|
|
|
|
* Location
|
|
|
|
|
* --------
|
|
|
|
|
* latitude,longitude[@altitude]
|
|
|
|
|
*/
|
2016-07-14 16:21:26 +01:00
|
|
|
|
function insert_location ( $text, $post ) {
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
// geo
|
|
|
|
|
$lat = \get_post_meta ( $post->ID, 'geo_latitude' , true );
|
|
|
|
|
$lon = \get_post_meta ( $post->ID, 'geo_longitude' , true );
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
if ( empty( $lat ) || empty( $lon ) )
|
2016-07-14 16:21:26 +01:00
|
|
|
|
return $text;
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$geo = "{$lat},{$lon}";
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$alt = \get_post_meta ( $post->ID, 'geo_altitude' , true );
|
|
|
|
|
if ( !empty( $alt ) )
|
|
|
|
|
$geo .= "@{$alt}";
|
2016-06-28 15:27:02 +01:00
|
|
|
|
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$text .= _insert_head ( "Location" );
|
|
|
|
|
$text .= "{$geo}";
|
|
|
|
|
|
|
|
|
|
return $text;
|
2016-06-28 15:27:02 +01:00
|
|
|
|
}
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
/**
|
|
|
|
|
*
|
2016-07-21 16:12:13 +01:00
|
|
|
|
* extends the $c with
|
|
|
|
|
*
|
|
|
|
|
* From
|
|
|
|
|
* ------
|
|
|
|
|
* Author Display Name [<author@email>]
|
|
|
|
|
* avatar URL
|
|
|
|
|
* [ author URL ]
|
2016-06-28 15:27:02 +01:00
|
|
|
|
*/
|
2016-07-21 16:12:13 +01:00
|
|
|
|
function comment_insert_from ( $c, $comment ) {
|
|
|
|
|
$c .= _insert_head( "From" );
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$c .= "{$comment->comment_author}";
|
2016-06-28 15:27:02 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
if ( ! empty( $comment->comment_author_email ) )
|
|
|
|
|
$c .= " <{$comment->comment_author_email}>";
|
2016-06-28 15:27:02 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
if ( $avatar = \get_comment_meta ($comment->comment_ID, "avatar", true))
|
|
|
|
|
$c .= "\n{$avatar}";
|
|
|
|
|
elseif ( ! empty( $comment->comment_author_email ) )
|
|
|
|
|
$c .= "\n". gravatar ( $comment->comment_author_email );
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
if ( ! empty( $comment->comment_author_url ))
|
|
|
|
|
$c .= "\n{$comment->comment_author_url}";
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
return $c;
|
2016-06-28 15:27:02 +01:00
|
|
|
|
}
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
/**
|
|
|
|
|
*
|
2016-07-21 16:12:13 +01:00
|
|
|
|
* extends the $c with
|
2016-06-28 15:27:02 +01:00
|
|
|
|
*
|
2016-07-21 16:12:13 +01:00
|
|
|
|
* (Type)
|
|
|
|
|
* ======
|
2016-06-28 15:27:02 +01:00
|
|
|
|
*/
|
2016-07-21 16:12:13 +01:00
|
|
|
|
function comment_insert_type ( $c, $comment ) {
|
|
|
|
|
if ( empty ( $comment->comment_type ) )
|
|
|
|
|
$type = "Reply";
|
2016-06-28 15:27:02 +01:00
|
|
|
|
else
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$type = ucfirst( $comment->comment_type );
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$c .= _insert_head( $type, 1 );
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
return $c;
|
|
|
|
|
}
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* extends the $text with
|
|
|
|
|
*
|
|
|
|
|
* At
|
|
|
|
|
* --
|
|
|
|
|
* (comment publish date in Y-m-d H:i:s P format)
|
|
|
|
|
*/
|
|
|
|
|
function comment_insert_at ( $c, $comment ) {
|
|
|
|
|
$c .= _insert_head( "At" );
|
|
|
|
|
$c .= date( 'Y-m-d H:i:s P', strtotime( $comment->comment_date ) );
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
return $c;
|
2016-07-14 16:21:26 +01:00
|
|
|
|
}
|
2016-07-09 21:25:43 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* extends the $c with
|
|
|
|
|
*
|
|
|
|
|
* \n\n (comment content) \n
|
|
|
|
|
*/
|
|
|
|
|
function comment_insert_content ( $c, $comment ) {
|
|
|
|
|
if ( ! empty( $comment->comment_content ) )
|
|
|
|
|
$c .= "\n\n" . $comment->comment_content . "\n";
|
2016-07-09 21:25:43 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
return $c;
|
|
|
|
|
}
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
/**
|
2016-07-21 16:12:13 +01:00
|
|
|
|
* fix all image attachments: resized -> original
|
2016-06-28 15:27:02 +01:00
|
|
|
|
*
|
|
|
|
|
*/
|
2016-07-21 16:12:13 +01:00
|
|
|
|
function post_content_resized2orig ( $content, $post ) {
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
$urlparts = parse_url( \site_url() );
|
|
|
|
|
$domain = $urlparts ['host'];
|
|
|
|
|
$wp_upload_dir = \wp_upload_dir();
|
|
|
|
|
$uploadurl = str_replace( '/', "\\/", trim( str_replace( \site_url(), '', $wp_upload_dir['url']), '/'));
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
$pregstr = "/((https?:\/\/". $domain .")?\/". $uploadurl ."\/.*\/[0-9]{4}\/[0-9]{2}\/)(.*)-([0-9]{1,4})×([0-9]{1,4})\.([a-zA-Z]{2,4})/";
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
preg_match_all( $pregstr, $content, $resized_images );
|
|
|
|
|
|
|
|
|
|
if ( !empty ( $resized_images[0] )) {
|
|
|
|
|
foreach ( $resized_images[0] as $cntr => $imgstr ) {
|
|
|
|
|
$done_images[ $resized_images[2][$cntr] ] = 1;
|
|
|
|
|
$fname = $resized_images[2][$cntr] . '.' . $resized_images[5][$cntr];
|
|
|
|
|
$width = $resized_images[3][$cntr];
|
|
|
|
|
$height = $resized_images[4][$cntr];
|
|
|
|
|
$r = $fname . '?resize=' . $width . ',' . $height;
|
|
|
|
|
$content = str_replace ( $imgstr, $r, $content );
|
2016-06-28 15:11:52 +01:00
|
|
|
|
}
|
2016-06-28 15:27:02 +01:00
|
|
|
|
}
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
$pregstr = "/(https?:\/\/". $domain .")?\/". $uploadurl ."\/.*\/[0-9]{4}\/[0-9]{2}\/(.*?)\.([a-zA-Z]{2,4})/";
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
preg_match_all( $pregstr, $content, $images );
|
|
|
|
|
if ( !empty ( $images[0] )) {
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
foreach ( $images[0] as $cntr=>$imgstr ) {
|
|
|
|
|
if ( !isset($done_images[ $images[1][$cntr] ]) ){
|
|
|
|
|
if ( !strstr($images[1][$cntr], 'http'))
|
|
|
|
|
$fname = $images[2][$cntr] . '.' . $images[3][$cntr];
|
|
|
|
|
else
|
|
|
|
|
$fname = $images[1][$cntr] . '.' . $images[2][$cntr];
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
$content = str_replace ( $imgstr, $fname, $content );
|
2016-06-28 15:11:52 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
2016-06-28 15:27:02 +01:00
|
|
|
|
}
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
return $content;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* get rid of wp_upload_dir in self urls
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function post_content_clean_uploaddir ( $content, $post ) {
|
|
|
|
|
|
|
|
|
|
$urlparts = parse_url( \site_url() );
|
|
|
|
|
$domain = $urlparts ['host'];
|
|
|
|
|
$wp_upload_dir = \wp_upload_dir();
|
|
|
|
|
$uploadurl = str_replace( '/', "\\/", trim( str_replace( \site_url(), '', $wp_upload_dir['url']), '/'));
|
|
|
|
|
|
|
|
|
|
$pattern = "/\({$wp_upload_dir['baseurl']}\/(.*?)\)/";
|
|
|
|
|
$search = str_replace( '/', '\/', $wp_upload_dir['baseurl'] );
|
|
|
|
|
$content = preg_replace( "/\({$search}\/(.*?)\)/", '(${1})', $content );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return $content;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* insert featured image
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function post_content_insert_featured ( $content, $post ) {
|
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
$thid = \get_post_thumbnail_id( $post->ID );
|
|
|
|
|
if ( ! empty( $thid ) ) {
|
|
|
|
|
$src = \wp_get_attachment_image_src( $thid, 'full' );
|
|
|
|
|
if ( isset($src[0]) ) {
|
|
|
|
|
$meta = \wp_get_attachment_metadata($thid);
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
if ( empty( $meta['image_meta']['title'] ) )
|
|
|
|
|
$title = $post->post_title;
|
|
|
|
|
else
|
|
|
|
|
$title = $meta['image_meta']['title'];
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$featured = "\n\n![{$title}]({$src[0]}){#img-{$thid}}";
|
|
|
|
|
$content .= apply_filters ( 'wp_flatexport_featured_image', $featured, $post );
|
2016-06-28 15:11:52 +01:00
|
|
|
|
}
|
2016-06-28 15:27:02 +01:00
|
|
|
|
}
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
return $content;
|
|
|
|
|
}
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
/**
|
|
|
|
|
* get rid of markdown extra {#img-ID} -s
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function post_content_clear_imgids ( $content, $post ) {
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$content = preg_replace( "/\{\#img-[0-9]+.*?\}/", "", $content );
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
return $content;
|
|
|
|
|
}
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
/**
|
|
|
|
|
* find markdown links and replace them with footnote versions
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function post_content_url2footnote ( $content, $post ) {
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
//
|
2016-06-28 15:27:02 +01:00
|
|
|
|
$pattern = "/\s+(\[([^\s].*?)\]\((.*?)(\s?+[\\\"\'].*?[\\\"\'])?\))/";
|
|
|
|
|
$matches = array();
|
|
|
|
|
preg_match_all( $pattern, $content, $matches );
|
|
|
|
|
// [1] -> array of []()
|
|
|
|
|
// [2] -> array of []
|
|
|
|
|
// [3] -> array of ()
|
|
|
|
|
// [4] -> (maybe) "" titles
|
|
|
|
|
if ( ! empty( $matches ) && isset( $matches[0] ) && ! empty( $matches[0] ) ) {
|
|
|
|
|
foreach ( $matches[1] as $cntr => $match ) {
|
|
|
|
|
$name = trim( $matches[2][$cntr] );
|
|
|
|
|
$url = trim( $matches[3][$cntr] );
|
2016-07-21 16:12:13 +01:00
|
|
|
|
if ( ! strstr( $url, 'http') )
|
|
|
|
|
$url = \site_url( $url );
|
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
$title = "";
|
|
|
|
|
|
|
|
|
|
if ( isset( $matches[4][$cntr] ) && !empty( $matches[4][$cntr] ) )
|
|
|
|
|
$title = " {$matches[4][$cntr]}";
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$refid = $cntr+1;
|
|
|
|
|
|
|
|
|
|
$footnotes[] = "[{$refid}]: {$url}{$title}";
|
|
|
|
|
$content = str_replace ( $match, "[" . trim( $matches[2][$cntr] ) . "][". $refid ."]" , $content );
|
2016-06-28 15:11:52 +01:00
|
|
|
|
}
|
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
$content = $content . "\n\n" . join( "\n", $footnotes );
|
2016-06-28 15:11:52 +01:00
|
|
|
|
}
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
return $content;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* find all second level markdown headers and replace them with underlined version
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function post_content_headers ( $content, $post ) {
|
|
|
|
|
|
|
|
|
|
$map = depthmap();
|
|
|
|
|
preg_match_all( "/^([#]+)\s?+(.*)$/m", $content, $matches );
|
|
|
|
|
|
|
|
|
|
if ( ! empty( $matches ) && isset( $matches[0] ) && ! empty( $matches[0] ) ) {
|
|
|
|
|
foreach ( $matches[0] as $cntr => $match ) {
|
|
|
|
|
$depth = strlen( trim( $matches[1][$cntr] ) );
|
|
|
|
|
$title = trim( $matches[2][$cntr] );
|
|
|
|
|
$content = str_replace ( $match, $title ."\n" . str_repeat( $map[ $depth ], mb_strlen( $title, 'UTF-8' ) ), $content );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $content;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* word-wrap magic
|
|
|
|
|
*
|
|
|
|
|
*
|
|
|
|
|
function post_content_wordwrap ( $content, $post ) {
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-09 21:25:43 +01:00
|
|
|
|
$fenced_o = array();
|
|
|
|
|
preg_match_all( "/^```(.*?)[\n\r](.*?)```/mis", $content, $fenced_o );
|
|
|
|
|
|
|
|
|
|
$content = wordwrap( $content, 72 );
|
|
|
|
|
|
|
|
|
|
$fenced_n = array();
|
|
|
|
|
preg_match_all( "/^```(.*?)[\n\r](.*?)```/mis", $content, $fenced_n );
|
|
|
|
|
|
|
|
|
|
foreach ( array_keys( $fenced_o[0] ) as $k ) {
|
|
|
|
|
if ( $fenced_o[0][$k] != $fenced_n[0][$k] ) {
|
|
|
|
|
$content = str_replace ( $fenced_n[0][$k], $fenced_o[0][$k], $content );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
return $content;
|
|
|
|
|
}
|
2016-07-21 16:12:13 +01:00
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* convert standalone urls to <url>
|
|
|
|
|
*
|
|
|
|
|
function post_content_urls ( $content, $post ) {
|
|
|
|
|
return $content = preg_replace("/\b((?:http|https)\:\/\/?[a-zA-Z0-9\.\/\?\:@\-_=#]+\.[a-zA-Z0-9\.\/\?\:@\-_=#&,\+%]*)(?:\s|\n|\r|$)/i", '<${1}>' . "\n", $content);
|
|
|
|
|
}
|
|
|
|
|
*/
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
/**
|
2016-07-21 16:12:13 +01:00
|
|
|
|
*
|
2016-06-28 15:27:02 +01:00
|
|
|
|
*/
|
2016-07-21 16:12:13 +01:00
|
|
|
|
function post_content ( &$post ) {
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
return trim (
|
|
|
|
|
apply_filters (
|
|
|
|
|
'wp_flatexport_content',
|
|
|
|
|
trim( $post->post_content ),
|
|
|
|
|
$post
|
|
|
|
|
)
|
|
|
|
|
);
|
|
|
|
|
}
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function export () {
|
|
|
|
|
|
|
|
|
|
if ( ! \is_singular() )
|
2016-06-28 15:27:02 +01:00
|
|
|
|
return false;
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$post = fix_post();
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
if ( $post === false )
|
|
|
|
|
return false;
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
// create directory structure
|
|
|
|
|
$filename = $post->post_name;
|
|
|
|
|
|
|
|
|
|
$flatroot = \WP_CONTENT_DIR . DIRECTORY_SEPARATOR . basedir;
|
|
|
|
|
$flatdir = $flatroot . DIRECTORY_SEPARATOR . $filename;
|
|
|
|
|
$flatfile = $flatdir . DIRECTORY_SEPARATOR . basefile;
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$post_timestamp = \get_the_modified_time( 'U', $post->ID );
|
|
|
|
|
$file_timestamp = 0;
|
|
|
|
|
|
|
|
|
|
if ( @file_exists($flatfile) ) {
|
|
|
|
|
$file_timestamp = @filemtime ( $flatfile );
|
2016-06-28 15:27:02 +01:00
|
|
|
|
}
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$mkdir = array ( $flatroot, $flatdir );
|
|
|
|
|
foreach ( $mkdir as $dir ) {
|
|
|
|
|
if ( !is_dir($dir)) {
|
|
|
|
|
if (!mkdir( $dir )) {
|
|
|
|
|
debug_log('Failed to create ' . $dir . ', exiting export', 4);
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2016-06-28 15:27:02 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
touch($flatdir, $post_timestamp);
|
2016-06-28 15:27:02 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
// get all the attachments
|
|
|
|
|
$attachments = \get_children( array (
|
|
|
|
|
'post_parent'=>$post->ID,
|
|
|
|
|
'post_type'=>'attachment',
|
|
|
|
|
'orderby'=>'menu_order',
|
|
|
|
|
'order'=>'asc'
|
|
|
|
|
));
|
|
|
|
|
|
|
|
|
|
// 100 is there for sanity
|
|
|
|
|
// hardlink all the attachments; no need for copy
|
|
|
|
|
// unless you're on a filesystem that does not support hardlinks
|
|
|
|
|
if ( !empty($attachments) && count($attachments) < maxattachments ) {
|
|
|
|
|
$out['attachments'] = array();
|
|
|
|
|
foreach ( $attachments as $aid => $attachment ) {
|
|
|
|
|
$attachment_path = \get_attached_file( $aid );
|
|
|
|
|
$attachment_file = basename( $attachment_path);
|
|
|
|
|
$target_file = $flatdir . DIRECTORY_SEPARATOR . $attachment_file;
|
|
|
|
|
debug ( "exporting {$attachment_file} for {$post->post_name}", 7 );
|
|
|
|
|
|
|
|
|
|
if ( is_file( $target_file ) )
|
|
|
|
|
continue;
|
|
|
|
|
|
|
|
|
|
if ( link( $attachment_path, $target_file ) )
|
|
|
|
|
continue;
|
|
|
|
|
else
|
|
|
|
|
debug( "could not hardlink '{$attachment_path}' to '{$target_file}'; trying to copy", 5);
|
|
|
|
|
|
|
|
|
|
if ( copy( $attachment_path, $target_file ) )
|
|
|
|
|
continue;
|
|
|
|
|
else
|
|
|
|
|
debug("could not copy '{$attachment_path}' to '{$target_file}'; saving attachment failed!", 4);
|
2016-06-28 15:27:02 +01:00
|
|
|
|
|
2016-06-28 15:11:52 +01:00
|
|
|
|
}
|
2016-07-21 16:12:13 +01:00
|
|
|
|
}
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
// deal with comments
|
|
|
|
|
$comments = get_comments ( array( 'post_id' => $post->ID ) );
|
|
|
|
|
if ( $comments ) {
|
|
|
|
|
foreach ($comments as $comment) {
|
|
|
|
|
export_comment ( $post, $comment );
|
|
|
|
|
}
|
2016-06-28 15:27:02 +01:00
|
|
|
|
}
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
// in case our export is fresh or we're not forcing updates on each and
|
|
|
|
|
// every time, walk away from this post
|
|
|
|
|
if ( $file_timestamp == $post_timestamp && force == false ) {
|
|
|
|
|
return true;
|
2016-06-28 15:27:02 +01:00
|
|
|
|
}
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$out = trim ( apply_filters ( 'wp_flatexport_post', "", $post ) );
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
// write log
|
|
|
|
|
debug ( "Exporting #{$post->ID}, {$post->post_name} to {$flatfile}", 6 );
|
|
|
|
|
file_put_contents ($flatfile, $out);
|
|
|
|
|
touch ( $flatfile, $post_timestamp );
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function export_comment ( $post, $comment ) {
|
|
|
|
|
$filename = $post->post_name;
|
|
|
|
|
$flatroot = \WP_CONTENT_DIR . DIRECTORY_SEPARATOR . basedir;
|
|
|
|
|
$flatdir = $flatroot . DIRECTORY_SEPARATOR . $filename;
|
|
|
|
|
|
|
|
|
|
$cfile = "comment_{$comment->comment_ID}.txt";
|
|
|
|
|
$cfile = $flatdir . DIRECTORY_SEPARATOR . $cfile;
|
|
|
|
|
|
|
|
|
|
$cf_timestamp = 0;
|
|
|
|
|
$c_timestamp = strtotime( $comment->comment_date );
|
|
|
|
|
|
|
|
|
|
if ( @file_exists($cfile) ) {
|
|
|
|
|
$cf_timestamp = @filemtime ( $cfile );
|
2016-06-28 15:11:52 +01:00
|
|
|
|
}
|
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
// non force mode means skip existing
|
|
|
|
|
if ( $c_timestamp == $cf_timestamp && force == false ) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$c = trim ( apply_filters ( 'wp_flatexport_comment', "", $comment ) );
|
|
|
|
|
|
|
|
|
|
debug ( "Exporting comment # {$comment->comment_ID} to {$cfile}", 6 );
|
|
|
|
|
file_put_contents ($cfile, $c);
|
|
|
|
|
touch ( $cfile, $c_timestamp );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
*
|
|
|
|
|
function yaml_header ( &$post ) {
|
|
|
|
|
if ( ! extension_loaded( 'yaml') || ! function_exists( 'yaml_emit') )
|
|
|
|
|
return false;
|
2016-06-28 15:27:02 +01:00
|
|
|
|
|
|
|
|
|
$tags = \wp_get_post_terms( $post->ID, 'post_tag' );
|
2016-07-21 16:12:13 +01:00
|
|
|
|
foreach ( $tags as $k => $tag ) {
|
|
|
|
|
$tags[ $k ] = "{$tag->name}";
|
|
|
|
|
}
|
2016-06-28 15:27:02 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$urls = get_insert_urls ( $post );
|
|
|
|
|
$permalink = \get_permalink( $post );
|
|
|
|
|
foreach ( $urls as $k => $url ) {
|
2016-07-09 21:25:43 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
if ( ! strstr( $url, site_url() ) )
|
|
|
|
|
unset ( $urls[ $k ] );
|
2016-07-09 21:25:43 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
if ( strstr ( $permalink, $url ) )
|
|
|
|
|
unset ( $urls[ $k ] );
|
2016-07-09 21:25:43 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
$urls[ $k ] = str_replace ( rtrim( site_url() . '/' ), '/', $url );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$yaml = array (
|
|
|
|
|
'title' => $post->post_title,
|
|
|
|
|
'description' => $post->post_excerpt,
|
|
|
|
|
'date' => \get_the_time( 'Y-m-d H:i:s P', $post->ID );
|
2016-06-28 15:27:02 +01:00
|
|
|
|
'tags' => $tags,
|
2016-07-21 16:12:13 +01:00
|
|
|
|
'aliases' => $urls,
|
|
|
|
|
'slug' => $post->post_name,
|
|
|
|
|
'url' => $permalink,
|
2016-06-28 15:27:02 +01:00
|
|
|
|
|
2016-07-21 16:12:13 +01:00
|
|
|
|
//$modified = \get_the_modified_time( 'Y-m-d H:i:s P', $post->ID );
|
|
|
|
|
);
|
2016-07-14 16:21:26 +01:00
|
|
|
|
|
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
}
|
2016-07-21 16:12:13 +01:00
|
|
|
|
*/
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
/**
|
|
|
|
|
* do everything to get the Post object
|
|
|
|
|
*/
|
|
|
|
|
function fix_post ( &$post = null ) {
|
|
|
|
|
if ($post === null || !is_post($post))
|
|
|
|
|
global $post;
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
if (is_post($post))
|
|
|
|
|
return $post;
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
return false;
|
|
|
|
|
}
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
/**
|
|
|
|
|
* test if an object is actually a post
|
|
|
|
|
*/
|
|
|
|
|
function is_post ( &$post ) {
|
|
|
|
|
if ( !empty($post) && is_object($post) && isset($post->ID) && !empty($post->ID) )
|
|
|
|
|
return true;
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
return false;
|
|
|
|
|
}
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* debug messages; will only work if WP_DEBUG is on
|
|
|
|
|
* or if the level is LOG_ERR, but that will kill the process
|
|
|
|
|
*
|
|
|
|
|
* @param string $message
|
|
|
|
|
* @param int $level
|
|
|
|
|
*
|
|
|
|
|
* @output log to syslog | wp_die on high level
|
|
|
|
|
* @return false on not taking action, true on log sent
|
|
|
|
|
*/
|
|
|
|
|
function debug( $message, $level = LOG_NOTICE ) {
|
|
|
|
|
if ( empty( $message ) )
|
|
|
|
|
return false;
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
if ( @is_array( $message ) || @is_object ( $message ) )
|
|
|
|
|
$message = json_encode($message);
|
|
|
|
|
|
|
|
|
|
$levels = array (
|
|
|
|
|
LOG_EMERG => 0, // system is unusable
|
|
|
|
|
LOG_ALERT => 1, // Alert action must be taken immediately
|
|
|
|
|
LOG_CRIT => 2, // Critical critical conditions
|
|
|
|
|
LOG_ERR => 3, // Error error conditions
|
|
|
|
|
LOG_WARNING => 4, // Warning warning conditions
|
|
|
|
|
LOG_NOTICE => 5, // Notice normal but significant condition
|
|
|
|
|
LOG_INFO => 6, // Informational informational messages
|
|
|
|
|
LOG_DEBUG => 7, // Debug debug-level messages
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
// number for number based comparison
|
|
|
|
|
// should work with the defines only, this is just a make-it-sure step
|
|
|
|
|
$level_ = $levels [ $level ];
|
|
|
|
|
|
|
|
|
|
// in case WordPress debug log has a minimum level
|
|
|
|
|
if ( defined ( '\WP_DEBUG_LEVEL' ) ) {
|
|
|
|
|
$wp_level = $levels [ \WP_DEBUG_LEVEL ];
|
|
|
|
|
if ( $level_ > $wp_level ) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
}
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
// ERR, CRIT, ALERT and EMERG
|
|
|
|
|
if ( 3 >= $level_ ) {
|
|
|
|
|
\wp_die( '<h1>Error:</h1>' . '<p>' . $message . '</p>' );
|
|
|
|
|
exit;
|
2016-06-28 15:11:52 +01:00
|
|
|
|
}
|
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
$trace = debug_backtrace();
|
|
|
|
|
$caller = $trace[1];
|
|
|
|
|
$parent = $caller['function'];
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
if (isset($caller['class']))
|
|
|
|
|
$parent = $caller['class'] . '::' . $parent;
|
2016-06-28 15:11:52 +01:00
|
|
|
|
|
2016-06-28 15:27:02 +01:00
|
|
|
|
return error_log( "{$parent}: {$message}" );
|
2016-07-21 16:12:13 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* generate gravatar img link
|
|
|
|
|
*/
|
|
|
|
|
function gravatar ( $email ) {
|
|
|
|
|
return sprintf(
|
|
|
|
|
'https://s.gravatar.com/avatar/%s?=64',
|
|
|
|
|
md5( strtolower( trim( $email ) ) )
|
|
|
|
|
);
|
2016-06-28 15:27:02 +01:00
|
|
|
|
}
|