X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;ds=inline;f=blogger%2Fblogger.php;h=e0b5f5352ea0102579bae05051f83fff58bc423d;hb=b8de9687b02326c3f5caf30df969a0e5db936dc0;hp=8d8051b0c2e6ba50e62506c147a1c42e73bda644;hpb=b8df74beca283afbdba2da9d8ef7fa1f10e8e4dd;p=friendica-addons.git
diff --git a/blogger/blogger.php b/blogger/blogger.php
index 8d8051b0..e0b5f535 100644
--- a/blogger/blogger.php
+++ b/blogger/blogger.php
@@ -3,55 +3,58 @@
* Name: Blogger Post Connector
* Description: Post to Blogger (or anything else which uses blogger XMLRPC API)
* Version: 1.0
- *
+ * Status: Unsupported
*/
use Friendica\App;
use Friendica\Content\Text\BBCode;
-use Friendica\Core\Addon;
-use Friendica\Core\L10n;
+use Friendica\Core\Hook;
use Friendica\Core\Logger;
-use Friendica\Core\PConfig;
+use Friendica\DI;
use Friendica\Util\Network;
-use Friendica\Util\Strings;
+use Friendica\Util\XML;
function blogger_install()
{
- Addon::registerHook('post_local', 'addon/blogger/blogger.php', 'blogger_post_local');
- Addon::registerHook('notifier_normal', 'addon/blogger/blogger.php', 'blogger_send');
- Addon::registerHook('jot_networks', 'addon/blogger/blogger.php', 'blogger_jot_nets');
- Addon::registerHook('connector_settings', 'addon/blogger/blogger.php', 'blogger_settings');
- Addon::registerHook('connector_settings_post', 'addon/blogger/blogger.php', 'blogger_settings_post');
+ Hook::register('hook_fork', 'addon/blogger/blogger.php', 'blogger_hook_fork');
+ Hook::register('post_local', 'addon/blogger/blogger.php', 'blogger_post_local');
+ Hook::register('notifier_normal', 'addon/blogger/blogger.php', 'blogger_send');
+ Hook::register('jot_networks', 'addon/blogger/blogger.php', 'blogger_jot_nets');
+ Hook::register('connector_settings', 'addon/blogger/blogger.php', 'blogger_settings');
+ Hook::register('connector_settings_post', 'addon/blogger/blogger.php', 'blogger_settings_post');
}
function blogger_uninstall()
{
- Addon::unregisterHook('post_local', 'addon/blogger/blogger.php', 'blogger_post_local');
- Addon::unregisterHook('notifier_normal', 'addon/blogger/blogger.php', 'blogger_send');
- Addon::unregisterHook('jot_networks', 'addon/blogger/blogger.php', 'blogger_jot_nets');
- Addon::unregisterHook('connector_settings', 'addon/blogger/blogger.php', 'blogger_settings');
- Addon::unregisterHook('connector_settings_post', 'addon/blogger/blogger.php', 'blogger_settings_post');
+ Hook::unregister('hook_fork', 'addon/blogger/blogger.php', 'blogger_hook_fork');
+ Hook::unregister('post_local', 'addon/blogger/blogger.php', 'blogger_post_local');
+ Hook::unregister('notifier_normal', 'addon/blogger/blogger.php', 'blogger_send');
+ Hook::unregister('jot_networks', 'addon/blogger/blogger.php', 'blogger_jot_nets');
+ Hook::unregister('connector_settings', 'addon/blogger/blogger.php', 'blogger_settings');
+ Hook::unregister('connector_settings_post', 'addon/blogger/blogger.php', 'blogger_settings_post');
// obsolete - remove
- Addon::unregisterHook('post_local_end', 'addon/blogger/blogger.php', 'blogger_send');
- Addon::unregisterHook('addon_settings', 'addon/blogger/blogger.php', 'blogger_settings');
- Addon::unregisterHook('addon_settings_post', 'addon/blogger/blogger.php', 'blogger_settings_post');
+ Hook::unregister('post_local_end', 'addon/blogger/blogger.php', 'blogger_send');
+ Hook::unregister('addon_settings', 'addon/blogger/blogger.php', 'blogger_settings');
+ Hook::unregister('addon_settings_post', 'addon/blogger/blogger.php', 'blogger_settings_post');
}
-function blogger_jot_nets(App $a, &$b)
+function blogger_jot_nets(App $a, array &$jotnets_fields)
{
if (!local_user()) {
return;
}
- $bl_post = PConfig::get(local_user(), 'blogger', 'post');
-
- if (intval($bl_post) == 1) {
- $bl_defpost = PConfig::get(local_user(), 'blogger', 'post_by_default');
- $selected = ((intval($bl_defpost) == 1) ? ' checked="checked" ' : '');
- $b .= '
'
- . L10n::t('Post to blogger') . '
';
+ if (DI::pConfig()->get(local_user(), 'blogger', 'post')) {
+ $jotnets_fields[] = [
+ 'type' => 'checkbox',
+ 'field' => [
+ 'blogger_enable',
+ DI::l10n()->t('Post to blogger'),
+ DI::pConfig()->get(local_user(), 'blogger', 'post_by_default')
+ ]
+ ];
}
}
@@ -64,69 +67,84 @@ function blogger_settings(App $a, &$s)
/* Add our stylesheet to the page so we can make our settings look nice */
- $a->page['htmlhead'] .= '' . "\r\n";
+ DI::page()['htmlhead'] .= '' . "\r\n";
/* Get the current state of our config variables */
- $enabled = PConfig::get(local_user(), 'blogger', 'post');
+ $enabled = DI::pConfig()->get(local_user(), 'blogger', 'post');
$checked = (($enabled) ? ' checked="checked" ' : '');
$css = (($enabled) ? '' : '-disabled');
- $def_enabled = PConfig::get(local_user(), 'blogger', 'post_by_default');
+ $def_enabled = DI::pConfig()->get(local_user(), 'blogger', 'post_by_default');
$def_checked = (($def_enabled) ? ' checked="checked" ' : '');
- $bl_username = PConfig::get(local_user(), 'blogger', 'bl_username');
- $bl_password = PConfig::get(local_user(), 'blogger', 'bl_password');
- $bl_blog = PConfig::get(local_user(), 'blogger', 'bl_blog');
+ $bl_username = DI::pConfig()->get(local_user(), 'blogger', 'bl_username');
+ $bl_password = DI::pConfig()->get(local_user(), 'blogger', 'bl_password');
+ $bl_blog = DI::pConfig()->get(local_user(), 'blogger', 'bl_blog');
/* Add some HTML to the existing form */
$s .= '';
- $s .= ''. L10n::t('Blogger Export').'
';
+ $s .= ''. DI::l10n()->t('Blogger Export').'
';
$s .= '';
$s .= '';
$s .= '
';
- $s .= ''. L10n::t('Blogger Export').'
';
+ $s .= ''. DI::l10n()->t('Blogger Export').'
';
$s .= '';
$s .= '
';
- $s .= '';
+ $s .= '';
$s .= '';
$s .= '
';
$s .= '
';
- $s .= '';
+ $s .= '';
$s .= '';
$s .= '
';
$s .= '
';
- $s .= '';
+ $s .= '';
$s .= '';
$s .= '
';
$s .= '
';
- $s .= '';
+ $s .= '';
$s .= '';
$s .= '
';
$s .= '
';
- $s .= '';
+ $s .= '';
$s .= '';
$s .= '
';
/* provide a submit button */
- $s .= '
';
+ $s .= '';
}
function blogger_settings_post(App $a, array &$b)
{
if (!empty($_POST['blogger-submit'])) {
- PConfig::set(local_user(), 'blogger', 'post', defaults($_POST, 'blogger', false));
- PConfig::set(local_user(), 'blogger', 'post_by_default', defaults($_POST, 'bl_bydefault', false));
- PConfig::set(local_user(), 'blogger', 'bl_username', trim($_POST['bl_username']));
- PConfig::set(local_user(), 'blogger', 'bl_password', trim($_POST['bl_password']));
- PConfig::set(local_user(), 'blogger', 'bl_blog', trim($_POST['bl_blog']));
+ DI::pConfig()->set(local_user(), 'blogger', 'post', $_POST['blogger'] ?? false);
+ DI::pConfig()->set(local_user(), 'blogger', 'post_by_default', $_POST['bl_bydefault'] ?? false);
+ DI::pConfig()->set(local_user(), 'blogger', 'bl_username', trim($_POST['bl_username']));
+ DI::pConfig()->set(local_user(), 'blogger', 'bl_password', trim($_POST['bl_password']));
+ DI::pConfig()->set(local_user(), 'blogger', 'bl_blog', trim($_POST['bl_blog']));
+ }
+}
+
+function blogger_hook_fork(App &$a, array &$b)
+{
+ if ($b['name'] != 'notifier_normal') {
+ return;
+ }
+
+ $post = $b['data'];
+
+ if ($post['deleted'] || $post['private'] || ($post['created'] !== $post['edited']) ||
+ !strstr($post['postopts'], 'blogger') || ($post['parent'] != $post['id'])) {
+ $b['execute'] = false;
+ return;
}
}
@@ -146,11 +164,11 @@ function blogger_post_local(App $a, array &$b)
return;
}
- $bl_post = intval(PConfig::get(local_user(), 'blogger', 'post'));
+ $bl_post = intval(DI::pConfig()->get(local_user(), 'blogger', 'post'));
- $bl_enable = (($bl_post && x($_REQUEST, 'blogger_enable')) ? intval($_REQUEST['blogger_enable']) : 0);
+ $bl_enable = (($bl_post && !empty($_REQUEST['blogger_enable'])) ? intval($_REQUEST['blogger_enable']) : 0);
- if ($b['api_source'] && intval(PConfig::get(local_user(), 'blogger', 'post_by_default'))) {
+ if ($b['api_source'] && intval(DI::pConfig()->get(local_user(), 'blogger', 'post_by_default'))) {
$bl_enable = 1;
}
@@ -179,14 +197,14 @@ function blogger_send(App $a, array &$b)
return;
}
- $bl_username = Strings::escape(PConfig::get($b['uid'], 'blogger', 'bl_username'));
- $bl_password = Strings::escape(PConfig::get($b['uid'], 'blogger', 'bl_password'));
- $bl_blog = PConfig::get($b['uid'], 'blogger', 'bl_blog');
+ $bl_username = XML::escape(DI::pConfig()->get($b['uid'], 'blogger', 'bl_username'));
+ $bl_password = XML::escape(DI::pConfig()->get($b['uid'], 'blogger', 'bl_password'));
+ $bl_blog = DI::pConfig()->get($b['uid'], 'blogger', 'bl_blog');
if ($bl_username && $bl_password && $bl_blog) {
- $title = '' . (($b['title']) ? $b['title'] : L10n::t('Post from Friendica')) . '';
+ $title = '' . (($b['title']) ? $b['title'] : DI::l10n()->t('Post from Friendica')) . '';
$post = $title . BBCode::convert($b['body']);
- $post = Strings::escape($post);
+ $post = XML::escape($post);
$xml = <<< EOT