LJ tweaks.
git-svn-id: http://svn.automattic.com/wordpress/trunk@3375 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
529d5294ec
commit
00e695e6f5
|
@ -1750,8 +1750,16 @@ function wp_handle_upload(&$file, $overrides = false) {
|
||||||
} else {
|
} else {
|
||||||
$number = '';
|
$number = '';
|
||||||
$filename = $file['name'];
|
$filename = $file['name'];
|
||||||
while ( file_exists($uploads['path'] . "/$filename") )
|
if ( empty($ext) )
|
||||||
$filename = str_replace("$number.$ext", ++$number . ".$ext", $filename);
|
$ext = '';
|
||||||
|
else
|
||||||
|
$ext = ".$ext";
|
||||||
|
while ( file_exists($uploads['path'] . "/$filename") ) {
|
||||||
|
if ( '' == "$number$ext" )
|
||||||
|
$filename = $filename . ++$number . $ext;
|
||||||
|
else
|
||||||
|
$filename = str_replace("$number$ext", ++$number . $ext, $filename);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Move the file to the uploads dir
|
// Move the file to the uploads dir
|
||||||
|
|
|
@ -2,7 +2,6 @@
|
||||||
|
|
||||||
class LJ_Import {
|
class LJ_Import {
|
||||||
|
|
||||||
var $posts = array ();
|
|
||||||
var $file;
|
var $file;
|
||||||
|
|
||||||
function header() {
|
function header() {
|
||||||
|
@ -25,75 +24,103 @@ class LJ_Import {
|
||||||
wp_import_upload_form("admin.php?import=livejournal&step=1");
|
wp_import_upload_form("admin.php?import=livejournal&step=1");
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_posts() {
|
function import_posts() {
|
||||||
global $wpdb, $current_user;
|
global $wpdb, $current_user;
|
||||||
|
|
||||||
set_magic_quotes_runtime(0);
|
set_magic_quotes_runtime(0);
|
||||||
$datalines = file($this->file); // Read the file into an array
|
$importdata = file($this->file); // Read the file into an array
|
||||||
$importdata = implode('', $datalines); // squish it
|
$importdata = implode('', $importdata); // squish it
|
||||||
$importdata = str_replace(array ("\r\n", "\r"), "\n", $importdata);
|
$importdata = str_replace(array ("\r\n", "\r"), "\n", $importdata);
|
||||||
|
|
||||||
preg_match_all('|<entry>(.*?)</entry>|is', $importdata, $this->posts);
|
preg_match_all('|<entry>(.*?)</entry>|is', $importdata, $posts);
|
||||||
$this->posts = $this->posts[1];
|
$posts = $posts[1];
|
||||||
$index = 0;
|
unset($importdata);
|
||||||
foreach ($this->posts as $post) {
|
echo '<ol>';
|
||||||
|
foreach ($posts as $post) {
|
||||||
|
flush();
|
||||||
preg_match('|<subject>(.*?)</subject>|is', $post, $post_title);
|
preg_match('|<subject>(.*?)</subject>|is', $post, $post_title);
|
||||||
$post_title = $wpdb->escape(trim($post_title[1]));
|
$post_title = $wpdb->escape(trim($post_title[1]));
|
||||||
if ( empty($post_title) ) {
|
if ( empty($post_title) ) {
|
||||||
preg_match('|<eventid>(.*?)</eventid>|is', $post, $post_title);
|
preg_match('|<itemid>(.*?)</itemid>|is', $post, $post_title);
|
||||||
$post_title = $wpdb->escape(trim($post_title[1]));
|
$post_title = $wpdb->escape(trim($post_title[1]));
|
||||||
}
|
}
|
||||||
|
|
||||||
preg_match('|<eventtime>(.*?)</eventtime>|is', $post, $post_date);
|
|
||||||
|
|
||||||
|
preg_match('|<eventtime>(.*?)</eventtime>|is', $post, $post_date);
|
||||||
$post_date = strtotime($post_date[1]);
|
$post_date = strtotime($post_date[1]);
|
||||||
$post_date = gmdate('Y-m-d H:i:s', $post_date);
|
$post_date = gmdate('Y-m-d H:i:s', $post_date);
|
||||||
|
|
||||||
preg_match('|<event>(.*?)</event>|is', $post, $post_content);
|
preg_match('|<event>(.*?)</event>|is', $post, $post_content);
|
||||||
$post_content = str_replace(array ('<![CDATA[', ']]>'), '', $wpdb->escape(trim($post_content[1])));
|
$post_content = str_replace(array ('<![CDATA[', ']]>'), '', trim($post_content[1]));
|
||||||
|
$post_content = $this->unhtmlentities($post_content);
|
||||||
if (!$post_content) {
|
|
||||||
// This is for feeds that put content in description
|
|
||||||
preg_match('|<description>(.*?)</description>|is', $post, $post_content);
|
|
||||||
$post_content = $wpdb->escape($this->unhtmlentities(trim($post_content[1])));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Clean up content
|
// Clean up content
|
||||||
$post_content = preg_replace('|<(/?[A-Z]+)|e', "'<' . strtolower('$1')", $post_content);
|
$post_content = preg_replace('|<(/?[A-Z]+)|e', "'<' . strtolower('$1')", $post_content);
|
||||||
$post_content = str_replace('<br>', '<br />', $post_content);
|
$post_content = str_replace('<br>', '<br />', $post_content);
|
||||||
$post_content = str_replace('<hr>', '<hr />', $post_content);
|
$post_content = str_replace('<hr>', '<hr />', $post_content);
|
||||||
|
$post_content = $wpdb->escape($post_content);
|
||||||
|
|
||||||
$post_author = $current_user->ID;
|
$post_author = $current_user->ID;
|
||||||
$post_status = 'publish';
|
$post_status = 'publish';
|
||||||
$this->posts[$index] = compact('post_author', 'post_date', 'post_content', 'post_title', 'post_status');
|
|
||||||
$index++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function import_posts() {
|
|
||||||
echo '<ol>';
|
|
||||||
|
|
||||||
foreach ($this->posts as $post) {
|
|
||||||
echo "<li>".__('Importing post...');
|
|
||||||
|
|
||||||
extract($post);
|
|
||||||
|
|
||||||
|
echo '<li>';
|
||||||
if ($post_id = post_exists($post_title, $post_content, $post_date)) {
|
if ($post_id = post_exists($post_title, $post_content, $post_date)) {
|
||||||
_e('Post already imported');
|
printf(__('Post <i>%s</i> already exists.'), stripslashes($post_title));
|
||||||
} else {
|
} else {
|
||||||
|
printf(__('Importing post <i>%s</i>...'), stripslashes($post_title));
|
||||||
|
$post = compact('post_author', 'post_date', 'post_content', 'post_title', 'post_status');
|
||||||
$post_id = wp_insert_post($post);
|
$post_id = wp_insert_post($post);
|
||||||
if (!$post_id) {
|
if (!$post_id) {
|
||||||
_e("Couldn't get post ID");
|
_e("Couldn't get post ID");
|
||||||
return;
|
echo '</li>';
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
_e('Done !');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
preg_match_all('|<comment>(.*?)</comment>|is', $post, $comments);
|
||||||
|
$comments = $comments[1];
|
||||||
|
|
||||||
|
if ( $comments ) {
|
||||||
|
$comment_post_ID = $post_id;
|
||||||
|
$num_comments = 0;
|
||||||
|
foreach ($comments as $comment) {
|
||||||
|
preg_match('|<event>(.*?)</event>|is', $comment, $comment_content);
|
||||||
|
$comment_content = str_replace(array ('<![CDATA[', ']]>'), '', trim($comment_content[1]));
|
||||||
|
$comment_content = $this->unhtmlentities($comment_content);
|
||||||
|
|
||||||
|
// Clean up content
|
||||||
|
$comment_content = preg_replace('|<(/?[A-Z]+)|e', "'<' . strtolower('$1')", $comment_content);
|
||||||
|
$comment_content = str_replace('<br>', '<br />', $comment_content);
|
||||||
|
$comment_content = str_replace('<hr>', '<hr />', $comment_content);
|
||||||
|
$comment_content = $wpdb->escape($comment_content);
|
||||||
|
|
||||||
|
preg_match('|<eventtime>(.*?)</eventtime>|is', $comment, $comment_date);
|
||||||
|
$comment_date = trim($comment_date[1]);
|
||||||
|
$comment_date = date('Y-m-d H:i:s', strtotime($comment_date));
|
||||||
|
|
||||||
|
preg_match('|<name>(.*?)</name>|is', $comment, $comment_author);
|
||||||
|
$comment_author = $wpdb->escape(trim($comment_author[1]));
|
||||||
|
|
||||||
|
preg_match('|<email>(.*?)</email>|is', $comment, $comment_author_email);
|
||||||
|
$comment_author_email = $wpdb->escape(trim($comment_author_email[1]));
|
||||||
|
|
||||||
|
$comment_approved = 1;
|
||||||
|
// Check if it's already there
|
||||||
|
if (!comment_exists($comment_author, $comment_date)) {
|
||||||
|
$commentdata = compact('comment_post_ID', 'comment_author', 'comment_author_email', 'comment_date', 'comment_content', 'comment_approved');
|
||||||
|
$commentdata = wp_filter_comment($commentdata);
|
||||||
|
wp_insert_comment($commentdata);
|
||||||
|
$num_comments++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ( $num_comments )
|
||||||
|
printf(__('(%s comments)'), $num_comments);
|
||||||
|
|
||||||
echo '</li>';
|
echo '</li>';
|
||||||
|
flush();
|
||||||
|
ob_flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
echo '</ol>';
|
echo '</ol>';
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function import() {
|
function import() {
|
||||||
|
@ -104,7 +131,6 @@ class LJ_Import {
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->file = $file['file'];
|
$this->file = $file['file'];
|
||||||
$this->get_posts();
|
|
||||||
$this->import_posts();
|
$this->import_posts();
|
||||||
wp_import_cleanup($file['id']);
|
wp_import_cleanup($file['id']);
|
||||||
|
|
||||||
|
@ -140,5 +166,5 @@ class LJ_Import {
|
||||||
|
|
||||||
$livejournal_import = new LJ_Import();
|
$livejournal_import = new LJ_Import();
|
||||||
|
|
||||||
//register_importer('livejournal', 'LiveJournal', __('Import posts from LiveJournal'), array ($livejournal_import, 'dispatch'));
|
register_importer('livejournal', 'LiveJournal', __('Import posts from LiveJournal'), array ($livejournal_import, 'dispatch'));
|
||||||
?>
|
?>
|
||||||
|
|
|
@ -76,6 +76,8 @@ function wp_insert_comment($commentdata) {
|
||||||
$comment_date_gmt = gmdate('Y-m-d H:i:s', strtotime($comment_date) );
|
$comment_date_gmt = gmdate('Y-m-d H:i:s', strtotime($comment_date) );
|
||||||
if ( ! isset($comment_parent) )
|
if ( ! isset($comment_parent) )
|
||||||
$comment_parent = 0;
|
$comment_parent = 0;
|
||||||
|
if ( ! isset($comment_approved) )
|
||||||
|
$comment_approved = 1;
|
||||||
|
|
||||||
$result = $wpdb->query("INSERT INTO $wpdb->comments
|
$result = $wpdb->query("INSERT INTO $wpdb->comments
|
||||||
(comment_post_ID, comment_author, comment_author_email, comment_author_url, comment_author_IP, comment_date, comment_date_gmt, comment_content, comment_approved, comment_agent, comment_type, comment_parent, user_id)
|
(comment_post_ID, comment_author, comment_author_email, comment_author_url, comment_author_IP, comment_date, comment_date_gmt, comment_content, comment_approved, comment_agent, comment_type, comment_parent, user_id)
|
||||||
|
|
Loading…
Reference in New Issue