allow html post to api

This commit is contained in:
Friendika 2011-09-11 21:52:50 -07:00
parent 7a06c7c3bf
commit 17b081f9f7
2 changed files with 31 additions and 10 deletions

View file

@ -466,6 +466,7 @@
} }
return null; return null;
} }
// TODO - media uploads // TODO - media uploads
function api_statuses_update(&$a, $type) { function api_statuses_update(&$a, $type) {
if (local_user()===false) return false; if (local_user()===false) return false;
@ -475,6 +476,31 @@
// logger('api_post: ' . print_r($_POST,true)); // logger('api_post: ' . print_r($_POST,true));
if(requestdata('htmlstatus')) {
require_once('library/HTMLPurifier.auto.php');
require_once('include/html2bbcode.php');
$txt = requestdata('htmlstatus');
if((strpos($txt,'<') !== false) || (strpos($txt,'>') !== false)) {
$txt = preg_replace('#<object[^>]+>.+?' . 'http://www.youtube.com/((?:v|cp)/[A-Za-z0-9\-_=]+).+?</object>#s',
'[youtube]$1[/youtube]', $txt);
$txt = preg_replace('#<iframe[^>].+?' . 'http://www.youtube.com/embed/([A-Za-z0-9\-_=]+).+?</iframe>#s',
'[youtube]$1[/youtube]', $txt);
$config = HTMLPurifier_Config::createDefault();
$config->set('Cache.DefinitionImpl', null);
$purifier = new HTMLPurifier($config);
$txt = $purifier->purify($txt);
$_POST['body'] = html2bbcode($txt);
}
}
else
$_POST['body'] = urldecode(requestdata('status')); $_POST['body'] = urldecode(requestdata('status'));
$parent = requestdata('in_reply_to_status_id'); $parent = requestdata('in_reply_to_status_id');

View file

@ -38,6 +38,7 @@ function item_post(&$a) {
call_hooks('post_local_start', $_POST); call_hooks('post_local_start', $_POST);
$api_source = ((x($_POST,'api_source') && $_POST['api_source']) ? true : false); $api_source = ((x($_POST,'api_source') && $_POST['api_source']) ? true : false);
$return_path = ((x($_POST,'return')) ? $_POST['return'] : '');
/** /**
* Is this a reply to something? * Is this a reply to something?
@ -834,12 +835,6 @@ function item_post(&$a) {
} }
} }
logger('post_complete'); logger('post_complete');
// figure out how to return, depending on from whence we came // figure out how to return, depending on from whence we came
@ -847,10 +842,10 @@ function item_post(&$a) {
if($api_source) if($api_source)
return; return;
if((x($_POST,'return')) && strlen($_POST['return'])) { if($return_path) {
logger('return: ' . $_POST['return']); goaway($a->get_baseurl() . "/" . $return_path);
goaway($a->get_baseurl() . "/" . $_POST['return'] );
} }
$json = array('success' => 1); $json = array('success' => 1);
if(x($_POST,'jsreload') && strlen($_POST['jsreload'])) if(x($_POST,'jsreload') && strlen($_POST['jsreload']))
$json['reload'] = $a->get_baseurl() . '/' . $_POST['jsreload']; $json['reload'] = $a->get_baseurl() . '/' . $_POST['jsreload'];