X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=dwpost%2Fdwpost.php;h=94d7937c8553b699af87b639d9f2215ed2c18108;hb=0afd633346b517894ff8e92c705bd5d052dd06a2;hp=c7bfd939fe57bbaee44f96c7b7a84da849f09ba3;hpb=0398585d6cb80a455ea79ce9a155e9f8c7895dbd;p=friendica-addons.git diff --git a/dwpost/dwpost.php b/dwpost/dwpost.php index c7bfd939..94d7937c 100644 --- a/dwpost/dwpost.php +++ b/dwpost/dwpost.php @@ -1,27 +1,29 @@ + * Author: Tony Baldwin * Author: Michael Johnston + * Author: Cat Gray */ +use Friendica\Core\Addon; +use Friendica\Core\PConfig; function dwpost_install() { - register_hook('post_local', 'addon/dwpost/dwpost.php', 'dwpost_post_local'); - register_hook('notifier_normal', 'addon/dwpost/dwpost.php', 'dwpost_send'); - register_hook('jot_networks', 'addon/dwpost/dwpost.php', 'dwpost_jot_nets'); - register_hook('connector_settings', 'addon/dwpost/dwpost.php', 'dwpost_settings'); - register_hook('connector_settings_post', 'addon/dwpost/dwpost.php', 'dwpost_settings_post'); + Addon::registerHook('post_local', 'addon/dwpost/dwpost.php', 'dwpost_post_local'); + Addon::registerHook('notifier_normal', 'addon/dwpost/dwpost.php', 'dwpost_send'); + Addon::registerHook('jot_networks', 'addon/dwpost/dwpost.php', 'dwpost_jot_nets'); + Addon::registerHook('connector_settings', 'addon/dwpost/dwpost.php', 'dwpost_settings'); + Addon::registerHook('connector_settings_post', 'addon/dwpost/dwpost.php', 'dwpost_settings_post'); } function dwpost_uninstall() { - unregister_hook('post_local', 'addon/dwpost/dwpost.php', 'dwpost_post_local'); - unregister_hook('notifier_normal', 'addon/dwpost/dwpost.php', 'dwpost_send'); - unregister_hook('jot_networks', 'addon/dwpost/dwpost.php', 'dwpost_jot_nets'); - unregister_hook('connector_settings', 'addon/dwpost/dwpost.php', 'dwpost_settings'); - unregister_hook('connector_settings_post', 'addon/dwpost/dwpost.php', 'dwpost_settings_post'); + Addon::unregisterHook('post_local', 'addon/dwpost/dwpost.php', 'dwpost_post_local'); + Addon::unregisterHook('notifier_normal', 'addon/dwpost/dwpost.php', 'dwpost_send'); + Addon::unregisterHook('jot_networks', 'addon/dwpost/dwpost.php', 'dwpost_jot_nets'); + Addon::unregisterHook('connector_settings', 'addon/dwpost/dwpost.php', 'dwpost_settings'); + Addon::unregisterHook('connector_settings_post', 'addon/dwpost/dwpost.php', 'dwpost_settings_post'); } @@ -30,9 +32,9 @@ function dwpost_jot_nets(&$a,&$b) { if(! local_user()) return; - $dw_post = get_pconfig(local_user(),'dwpost','post'); + $dw_post = PConfig::get(local_user(),'dwpost','post'); if(intval($dw_post) == 1) { - $dw_defpost = get_pconfig(local_user(),'dwpost','post_by_default'); + $dw_defpost = PConfig::get(local_user(),'dwpost','post_by_default'); $selected = ((intval($dw_defpost) == 1) ? ' checked="checked" ' : ''); $b .= '
' . t('Post to Dreamwidth') . '
'; @@ -51,22 +53,28 @@ function dwpost_settings(&$a,&$s) { /* Get the current state of our config variables */ - $enabled = get_pconfig(local_user(),'dwpost','post'); + $enabled = PConfig::get(local_user(),'dwpost','post'); $checked = (($enabled) ? ' checked="checked" ' : ''); - $def_enabled = get_pconfig(local_user(),'dwpost','post_by_default'); + $def_enabled = PConfig::get(local_user(),'dwpost','post_by_default'); $def_checked = (($def_enabled) ? ' checked="checked" ' : ''); - $dw_username = get_pconfig(local_user(), 'dwpost', 'dw_username'); - $dw_password = get_pconfig(local_user(), 'dwpost', 'dw_password'); + $dw_username = PConfig::get(local_user(), 'dwpost', 'dw_username'); + $dw_password = PConfig::get(local_user(), 'dwpost', 'dw_password'); /* Add some HTML to the existing form */ - $s .= '
'; - $s .= '

' . t('Dreamwidth Post Settings') . '

'; + $s .= ''; + $s .= '

'. t("Dreamwidth Export").'

'; + $s .= '
'; + $s .= ''; } @@ -98,10 +106,10 @@ function dwpost_settings_post(&$a,&$b) { if(x($_POST,'dwpost-submit')) { - set_pconfig(local_user(),'dwpost','post',intval($_POST['dwpost'])); - set_pconfig(local_user(),'dwpost','post_by_default',intval($_POST['dw_bydefault'])); - set_pconfig(local_user(),'dwpost','dw_username',trim($_POST['dw_username'])); - set_pconfig(local_user(),'dwpost','dw_password',trim($_POST['dw_password'])); + PConfig::set(local_user(),'dwpost','post',intval($_POST['dwpost'])); + PConfig::set(local_user(),'dwpost','post_by_default',intval($_POST['dw_bydefault'])); + PConfig::set(local_user(),'dwpost','dw_username',trim($_POST['dw_username'])); + PConfig::set(local_user(),'dwpost','dw_password',trim($_POST['dw_password'])); } @@ -120,11 +128,11 @@ function dwpost_post_local(&$a,&$b) { if($b['private'] || $b['parent']) return; - $dw_post = intval(get_pconfig(local_user(),'dwpost','post')); + $dw_post = intval(PConfig::get(local_user(),'dwpost','post')); $dw_enable = (($dw_post && x($_REQUEST,'dwpost_enable')) ? intval($_REQUEST['dwpost_enable']) : 0); - if($_REQUEST['api_source'] && intval(get_pconfig(local_user(),'dwpost','post_by_default'))) + if($_REQUEST['api_source'] && intval(PConfig::get(local_user(),'dwpost','post_by_default'))) $dw_enable = 1; if(! $dw_enable) @@ -149,7 +157,7 @@ function dwpost_send(&$a,&$b) { if($b['parent'] != $b['id']) return; - // dreamwidth post in the LJ user's timezone. + // dreamwidth post in the LJ user's timezone. // Hopefully the person's Friendica account // will be set to the same thing. @@ -159,10 +167,10 @@ function dwpost_send(&$a,&$b) { intval($b['uid']) ); if($x && strlen($x[0]['timezone'])) - $tz = $x[0]['timezone']; + $tz = $x[0]['timezone']; - $dw_username = get_pconfig($b['uid'],'dwpost','dw_username'); - $dw_password = get_pconfig($b['uid'],'dwpost','dw_password'); + $dw_username = PConfig::get($b['uid'],'dwpost','dw_username'); + $dw_password = PConfig::get($b['uid'],'dwpost','dw_password'); $dw_blog = 'http://www.dreamwidth.org/interface/xmlrpc'; if($dw_username && $dw_password && $dw_blog) { @@ -173,6 +181,7 @@ function dwpost_send(&$a,&$b) { $title = $b['title']; $post = bbcode($b['body']); $post = xmlify($post); + $tags = dwpost_get_tags($b['tag']); $date = datetime_convert('UTC',$tz,$b['created'],'Y-m-d H:i:s'); $year = intval(substr($date,0,4)); @@ -200,7 +209,7 @@ function dwpost_send(&$a,&$b) { props useragentFriendica -taglistfriendica +taglist$tags @@ -211,9 +220,15 @@ EOT; logger('dwpost: data: ' . $xml, LOGGER_DATA); if($dw_blog !== 'test') - $x = post_url($dw_blog,$xml); + $x = post_url($dw_blog,$xml,["Content-Type: text/xml"]); logger('posted to dreamwidth: ' . ($x) ? $x : '', LOGGER_DEBUG); } } +function dwpost_get_tags($post) +{ + preg_match_all("/\]([^\[#]+)\[/",$post,$matches); + $tags = implode(', ',$matches[1]); + return $tags; +}