]> git.mxchange.org Git - friendica-addons.git/blobdiff - diaspora/diaspora.php
Rewrite: (#680)
[friendica-addons.git] / diaspora / diaspora.php
index 04ed24ca84b42d12d5f3dfed190a3e3fecaacdf3..a547255821144c0e5adf133b338ede76a79e700b 100644 (file)
@@ -7,56 +7,70 @@
  * Author: Michael Vogel <heluecht@pirati.ca>
  */
 
-require_once("addon/diaspora/Diaspora_Connection.php");
+require_once 'addon/diaspora/Diaspora_Connection.php';
 
+use Friendica\App;
+use Friendica\Content\Text\BBCode;
+use Friendica\Core\Addon;
+use Friendica\Core\L10n;
 use Friendica\Core\PConfig;
-use Friendica\Database\DBM;
-
-function diaspora_install() {
-       register_hook('post_local',           'addon/diaspora/diaspora.php', 'diaspora_post_local');
-       register_hook('notifier_normal',      'addon/diaspora/diaspora.php', 'diaspora_send');
-       register_hook('jot_networks',         'addon/diaspora/diaspora.php', 'diaspora_jot_nets');
-       register_hook('connector_settings',      'addon/diaspora/diaspora.php', 'diaspora_settings');
-       register_hook('connector_settings_post', 'addon/diaspora/diaspora.php', 'diaspora_settings_post');
-       register_hook('queue_predeliver', 'addon/diaspora/diaspora.php', 'diaspora_queue_hook');
+use Friendica\Core\Protocol;
+use Friendica\Database\DBA;
+use Friendica\Model\Queue;
+
+function diaspora_install()
+{
+       Addon::registerHook('post_local',              'addon/diaspora/diaspora.php', 'diaspora_post_local');
+       Addon::registerHook('notifier_normal',         'addon/diaspora/diaspora.php', 'diaspora_send');
+       Addon::registerHook('jot_networks',            'addon/diaspora/diaspora.php', 'diaspora_jot_nets');
+       Addon::registerHook('connector_settings',      'addon/diaspora/diaspora.php', 'diaspora_settings');
+       Addon::registerHook('connector_settings_post', 'addon/diaspora/diaspora.php', 'diaspora_settings_post');
+       Addon::registerHook('queue_predeliver',        'addon/diaspora/diaspora.php', 'diaspora_queue_hook');
 }
-function diaspora_uninstall() {
-       unregister_hook('post_local',       'addon/diaspora/diaspora.php', 'diaspora_post_local');
-       unregister_hook('notifier_normal',  'addon/diaspora/diaspora.php', 'diaspora_send');
-       unregister_hook('jot_networks',     'addon/diaspora/diaspora.php', 'diaspora_jot_nets');
-       unregister_hook('connector_settings',      'addon/diaspora/diaspora.php', 'diaspora_settings');
-       unregister_hook('connector_settings_post', 'addon/diaspora/diaspora.php', 'diaspora_settings_post');
-       unregister_hook('queue_predeliver', 'addon/diaspora/diaspora.php', 'diaspora_queue_hook');
+
+function diaspora_uninstall()
+{
+       Addon::unregisterHook('post_local',              'addon/diaspora/diaspora.php', 'diaspora_post_local');
+       Addon::unregisterHook('notifier_normal',         'addon/diaspora/diaspora.php', 'diaspora_send');
+       Addon::unregisterHook('jot_networks',            'addon/diaspora/diaspora.php', 'diaspora_jot_nets');
+       Addon::unregisterHook('connector_settings',      'addon/diaspora/diaspora.php', 'diaspora_settings');
+       Addon::unregisterHook('connector_settings_post', 'addon/diaspora/diaspora.php', 'diaspora_settings_post');
+       Addon::unregisterHook('queue_predeliver',        'addon/diaspora/diaspora.php', 'diaspora_queue_hook');
 }
 
+function diaspora_jot_nets(App $a, &$b)
+{
+       if (!local_user()) {
+               return;
+       }
+
+       $diaspora_post = PConfig::get(local_user(), 'diaspora', 'post');
+
+       if (intval($diaspora_post) == 1) {
+               $diaspora_defpost = PConfig::get(local_user(), 'diaspora', 'post_by_default');
 
-function diaspora_jot_nets(&$a,&$b) {
-    if(! local_user())
-        return;
+               $selected = ((intval($diaspora_defpost) == 1) ? ' checked="checked" ' : '');
 
-    $diaspora_post = PConfig::get(local_user(),'diaspora','post');
-    if(intval($diaspora_post) == 1) {
-        $diaspora_defpost = PConfig::get(local_user(),'diaspora','post_by_default');
-        $selected = ((intval($diaspora_defpost) == 1) ? ' checked="checked" ' : '');
-        $b .= '<div class="profile-jot-net"><input type="checkbox" name="diaspora_enable"' . $selected . ' value="1" /> '
-            . t('Post to Diaspora') . '</div>';
-    }
+               $b .= '<div class="profile-jot-net"><input type="checkbox" name="diaspora_enable"' . $selected . ' value="1" /> '
+               . L10n::t('Post to Diaspora') . '</div>';
+       }
 }
 
-function diaspora_queue_hook(&$a,&$b) {
+function diaspora_queue_hook(App $a, &$b) {
        $hostname = $a->get_hostname();
 
        $qi = q("SELECT * FROM `queue` WHERE `network` = '%s'",
-               dbesc(NETWORK_DIASPORA2)
+               DBA::escape(Protocol::DIASPORA2)
        );
-       if(! count($qi))
-               return;
 
-       require_once('include/queue_fn.php');
+       if (!DBA::isResult($qi)) {
+               return;
+       }
 
-       foreach($qi as $x) {
-               if($x['network'] !== NETWORK_DIASPORA2)
+       foreach ($qi as $x) {
+               if ($x['network'] !== Protocol::DIASPORA2) {
                        continue;
+               }
 
                logger('diaspora_queue: run');
 
@@ -64,19 +78,21 @@ function diaspora_queue_hook(&$a,&$b) {
                        WHERE `contact`.`self` = 1 AND `contact`.`id` = %d LIMIT 1",
                        intval($x['cid'])
                );
-               if(! count($r))
+
+               if (!DBA::isResult($r)) {
                        continue;
+               }
 
                $userdata = $r[0];
 
-               $handle = PConfig::get($userdata['uid'],'diaspora','handle');
-               $password = PConfig::get($userdata['uid'],'diaspora','password');
-               $aspect = PConfig::get($userdata['uid'],'diaspora','aspect');
+               $handle   = PConfig::get($userdata['uid'], 'diaspora', 'handle');
+               $password = PConfig::get($userdata['uid'], 'diaspora', 'password');
+               $aspect   = PConfig::get($userdata['uid'], 'diaspora', 'aspect');
 
                $success = false;
 
                if ($handle && $password) {
-                        logger('diaspora_queue: able to post for user '.$handle);
+                       logger('diaspora_queue: able to post for user '.$handle);
 
                        $z = unserialize($x['content']);
 
@@ -93,28 +109,30 @@ function diaspora_queue_hook(&$a,&$b) {
                                $conn->provider = $hostname;
                                $conn->postStatusMessage($post, $aspect);
 
-                                logger('diaspora_queue: send '.$userdata['uid'].' success', LOGGER_DEBUG);
+                               logger('diaspora_queue: send '.$userdata['uid'].' success', LOGGER_DEBUG);
 
-                                $success = true;
+                               $success = true;
 
-                                remove_queue_item($x['id']);
+                               Queue::removeItem($x['id']);
                        } catch (Exception $e) {
                                logger("diaspora_queue: Send ".$userdata['uid']." failed: ".$e->getMessage(), LOGGER_DEBUG);
                        }
-               } else
+               } else {
                        logger('diaspora_queue: send '.$userdata['uid'].' missing username or password', LOGGER_DEBUG);
+               }
 
                if (!$success) {
                        logger('diaspora_queue: delayed');
-                       update_queue_time($x['id']);
+                       Queue::updateTime($x['id']);
                }
        }
 }
 
-function diaspora_settings(&$a,&$s) {
-
-       if(! local_user())
+function diaspora_settings(App $a, &$s)
+{
+       if (! local_user()) {
                return;
+       }
 
        /* Add our stylesheet to the page so we can make our settings look nice */
 
@@ -137,10 +155,11 @@ function diaspora_settings(&$a,&$s) {
        $status = "";
 
        $r = q("SELECT `addr` FROM `contact` WHERE `self` AND `uid` = %d", intval(local_user()));
-       if (DBM::is_result($r)) {
-               $status = sprintf(t("Please remember: You can always be reached from Diaspora with your Friendica handle %s. "), $r[0]['addr']);
-               $status .= t('This connector is only meant if you still want to use your old Diaspora account for some time. ');
-               $status .= sprintf(t('However, it is preferred that you tell your Diaspora contacts the new handle %s instead.'), $r[0]['addr']);
+
+       if (DBA::isResult($r)) {
+               $status = L10n::t("Please remember: You can always be reached from Diaspora with your Friendica handle %s. ", $r[0]['addr']);
+               $status .= L10n::t('This connector is only meant if you still want to use your old Diaspora account for some time. ');
+               $status .= L10n::t('However, it is preferred that you tell your Diaspora contacts the new handle %s instead.', $r[0]['addr']);
        }
 
        $aspects = false;
@@ -149,19 +168,20 @@ function diaspora_settings(&$a,&$s) {
                $conn = new Diaspora_Connection($handle, $password);
                $conn->logIn();
                $aspects = $conn->getAspects();
+
                if (!$aspects) {
-                       $status = t("Can't login to your Diaspora account. Please check handle (in the format user@domain.tld) and password.");
+                       $status = L10n::t("Can't login to your Diaspora account. Please check handle (in the format user@domain.tld) and password.");
                }
        }
 
        /* Add some HTML to the existing form */
 
        $s .= '<span id="settings_diaspora_inflated" class="settings-block fakelink" style="display: block;" onclick="openClose(\'settings_diaspora_expanded\'); openClose(\'settings_diaspora_inflated\');">';
-       $s .= '<img class="connector'.$css.'" src="images/diaspora-logo.png" /><h3 class="connector">'. t('Diaspora Export').'</h3>';
+       $s .= '<img class="connector'.$css.'" src="images/diaspora-logo.png" /><h3 class="connector">'. L10n::t('Diaspora Export').'</h3>';
        $s .= '</span>';
        $s .= '<div id="settings_diaspora_expanded" class="settings-block" style="display: none;">';
        $s .= '<span class="fakelink" onclick="openClose(\'settings_diaspora_expanded\'); openClose(\'settings_diaspora_inflated\');">';
-       $s .= '<img class="connector'.$css.'" src="images/diaspora-logo.png" /><h3 class="connector">'. t('Diaspora Export').'</h3>';
+       $s .= '<img class="connector'.$css.'" src="images/diaspora-logo.png" /><h3 class="connector">'. L10n::t('Diaspora Export').'</h3>';
        $s .= '</span>';
 
        if ($status) {
@@ -171,32 +191,32 @@ function diaspora_settings(&$a,&$s) {
        }
 
        $s .= '<div id="diaspora-enable-wrapper">';
-       $s .= '<label id="diaspora-enable-label" for="diaspora-checkbox">' . t('Enable Diaspora Post Plugin') . '</label>';
+       $s .= '<label id="diaspora-enable-label" for="diaspora-checkbox">' . L10n::t('Enable Diaspora Post Addon') . '</label>';
        $s .= '<input id="diaspora-checkbox" type="checkbox" name="diaspora" value="1" ' . $checked . '/>';
        $s .= '</div><div class="clear"></div>';
 
        $s .= '<div id="diaspora-username-wrapper">';
-       $s .= '<label id="diaspora-username-label" for="diaspora-username">' . t('Diaspora handle') . '</label>';
+       $s .= '<label id="diaspora-username-label" for="diaspora-username">' . L10n::t('Diaspora handle') . '</label>';
        $s .= '<input id="diaspora-username" type="text" name="handle" value="' . $handle . '" />';
        $s .= '</div><div class="clear"></div>';
 
        $s .= '<div id="diaspora-password-wrapper">';
-       $s .= '<label id="diaspora-password-label" for="diaspora-password">' . t('Diaspora password') . '</label>';
+       $s .= '<label id="diaspora-password-label" for="diaspora-password">' . L10n::t('Diaspora password') . '</label>';
        $s .= '<input id="diaspora-password" type="password" name="password" value="' . $password . '" />';
        $s .= '</div><div class="clear"></div>';
 
        if ($aspects) {
                $single_aspect =  new stdClass();
                $single_aspect->id = 'all_aspects';
-               $single_aspect->name = t('All aspects');
+               $single_aspect->name = L10n::t('All aspects');
                $aspects[] = $single_aspect;
 
                $single_aspect =  new stdClass();
                $single_aspect->id = 'public';
-               $single_aspect->name = t('Public');
+               $single_aspect->name = L10n::t('Public');
                $aspects[] = $single_aspect;
 
-               $s .= '<label id="diaspora-aspect-label" for="diaspora-aspect">' . t('Post to aspect:') . '</label>';
+               $s .= '<label id="diaspora-aspect-label" for="diaspora-aspect">' . L10n::t('Post to aspect:') . '</label>';
                $s .= '<select name="aspect" id="diaspora-aspect">';
                foreach($aspects as $single_aspect) {
                        if ($single_aspect->id == $aspect)
@@ -210,32 +230,30 @@ function diaspora_settings(&$a,&$s) {
        }
 
        $s .= '<div id="diaspora-bydefault-wrapper">';
-       $s .= '<label id="diaspora-bydefault-label" for="diaspora-bydefault">' . t('Post to Diaspora by default') . '</label>';
+       $s .= '<label id="diaspora-bydefault-label" for="diaspora-bydefault">' . L10n::t('Post to Diaspora by default') . '</label>';
        $s .= '<input id="diaspora-bydefault" type="checkbox" name="diaspora_bydefault" value="1" ' . $def_checked . '/>';
        $s .= '</div><div class="clear"></div>';
 
        /* provide a submit button */
 
-       $s .= '<div class="settings-submit-wrapper" ><input type="submit" id="diaspora-submit" name="diaspora-submit" class="settings-submit" value="' . t('Save Settings') . '" /></div></div>';
+       $s .= '<div class="settings-submit-wrapper" ><input type="submit" id="diaspora-submit" name="diaspora-submit" class="settings-submit" value="' . L10n::t('Save Settings') . '" /></div></div>';
 
 }
 
 
-function diaspora_settings_post(&$a,&$b) {
-
-       if(x($_POST,'diaspora-submit')) {
-
-               PConfig::set(local_user(),'diaspora','post',intval($_POST['diaspora']));
-               PConfig::set(local_user(),'diaspora','post_by_default',intval($_POST['diaspora_bydefault']));
-               PConfig::set(local_user(),'diaspora','handle',trim($_POST['handle']));
-               PConfig::set(local_user(),'diaspora','password',trim($_POST['password']));
-               PConfig::set(local_user(),'diaspora','aspect',trim($_POST['aspect']));
+function diaspora_settings_post(App $a, &$b)
+{
+       if (!empty($_POST['diaspora-submit'])) {
+               PConfig::set(local_user(),'diaspora', 'post'           , intval($_POST['diaspora']));
+               PConfig::set(local_user(),'diaspora', 'post_by_default', intval($_POST['diaspora_bydefault']));
+               PConfig::set(local_user(),'diaspora', 'handle'         , trim($_POST['handle']));
+               PConfig::set(local_user(),'diaspora', 'password'       , trim($_POST['password']));
+               PConfig::set(local_user(),'diaspora', 'aspect'         , trim($_POST['aspect']));
        }
-
 }
 
-function diaspora_post_local(&$a,&$b) {
-
+function diaspora_post_local(App $a, array &$b)
+{
        if ($b['edit']) {
                return;
        }
@@ -267,26 +285,28 @@ function diaspora_post_local(&$a,&$b) {
        $b['postopts'] .= 'diaspora';
 }
 
-
-
-
-function diaspora_send(&$a,&$b) {
+function diaspora_send(App $a, array &$b)
+{
        $hostname = $a->get_hostname();
 
        logger('diaspora_send: invoked');
 
-       if($b['deleted'] || $b['private'] || ($b['created'] !== $b['edited']))
+       if ($b['deleted'] || $b['private'] || ($b['created'] !== $b['edited'])) {
                return;
+       }
 
-       if(! strstr($b['postopts'],'diaspora'))
+       if (!strstr($b['postopts'],'diaspora')) {
                return;
+       }
 
-       if($b['parent'] != $b['id'])
+       if ($b['parent'] != $b['id']) {
                return;
+       }
 
        // Dont't post if the post doesn't belong to us.
        // This is a check for forum postings
-       $self = dba::select('contact', array('id'), array('uid' => $b['uid'], 'self' => true), array('limit' => 1));
+       $self = DBA::selectFirst('contact', ['id'], ['uid' => $b['uid'], 'self' => true]);
+
        if ($b['contact-id'] != $self['id']) {
                return;
        }
@@ -298,21 +318,21 @@ function diaspora_send(&$a,&$b) {
        $aspect = PConfig::get($b['uid'],'diaspora','aspect');
 
        if ($handle && $password) {
-
                logger('diaspora_send: all values seem to be okay', LOGGER_DEBUG);
 
-               require_once('include/bb2diaspora.php');
-               $tag_arr = array();
+               $tag_arr = [];
                $tags = '';
                $x = preg_match_all('/\#\[(.*?)\](.*?)\[/',$b['tag'],$matches,PREG_SET_ORDER);
 
-               if($x) {
-                       foreach($matches as $mtch) {
+               if ($x) {
+                       foreach ($matches as $mtch) {
                                $tag_arr[] = $mtch[2];
                        }
                }
-               if(count($tag_arr))
+
+               if (count($tag_arr)) {
                        $tags = implode(',',$tag_arr);
+               }
 
                $title = $b['title'];
                $body = $b['body'];
@@ -329,17 +349,18 @@ function diaspora_send(&$a,&$b) {
                // remove multiple newlines
                do {
                        $oldbody = $body;
-                        $body = str_replace("\n\n\n", "\n\n", $body);
-                } while ($oldbody != $body);
+                       $body = str_replace("\n\n\n", "\n\n", $body);
+               } while ($oldbody != $body);
 
                // convert to markdown
-               $body = bb2diaspora($body, false, true);
+               $body = BBCode::toMarkdown($body);
 
                // Adding the title
-               if(strlen($title))
+               if (strlen($title)) {
                        $body = "## ".html_entity_decode($title)."\n\n".$body;
+               }
 
-               require_once("addon/diaspora/diasphp.php");
+               require_once "addon/diaspora/diasphp.php";
 
                try {
                        logger('diaspora_send: prepare', LOGGER_DEBUG);
@@ -361,10 +382,10 @@ function diaspora_send(&$a,&$b) {
                        if (count($r))
                                $a->contact = $r[0]["id"];
 
-                       $s = serialize(array('url' => $url, 'item' => $b['id'], 'post' => $body));
-                       require_once('include/queue_fn.php');
-                       add_to_queue($a->contact,NETWORK_DIASPORA2,$s);
-                       notice(t('Diaspora post failed. Queued for retry.').EOL);
+                       $s = serialize(['url' => $url, 'item' => $b['id'], 'post' => $body]);
+
+                       Queue::add($a->contact, Protocol::DIASPORA2, $s);
+                       notice(L10n::t('Diaspora post failed. Queued for retry.').EOL);
                }
        }
 }