]> git.mxchange.org Git - friendica.git/blobdiff - mod/crepair.php
Restore correct highlighted contact tabs
[friendica.git] / mod / crepair.php
index cfe0e3e286efd93ed9e88f550e3163e4b243b739..b9b8651439c531fb84c1f181387782e28daa6d21 100644 (file)
@@ -2,33 +2,23 @@
 /**
  * @file mod/crepair.php
  */
+
 use Friendica\App;
 use Friendica\Core\Config;
-use Friendica\Database\DBM;
-use Friendica\Model\Contact;
-use Friendica\Model\Profile;
-
-require_once 'mod/contacts.php';
+use Friendica\Core\L10n;
+use Friendica\Core\Logger;
+use Friendica\Core\Protocol;
+use Friendica\Core\Renderer;
+use Friendica\Database\DBA;
+use Friendica\Model;
+use Friendica\Module;
+use Friendica\Util\Strings;
 
 function crepair_init(App $a)
 {
        if (!local_user()) {
                return;
        }
-
-       $contact = null;
-       if (($a->argc == 2) && intval($a->argv[1])) {
-               $contact = dba::selectFirst('contact', [], ['uid' => local_user(), 'id' => $a->argv[1]]);
-       }
-
-       if (!x($a->page, 'aside')) {
-               $a->page['aside'] = '';
-       }
-
-       if (DBM::is_result($contact)) {
-               $a->data['contact'] = $contact;
-               Profile::load($a, "", 0, Contact::getDetailsByURL($contact["url"]));
-       }
 }
 
 function crepair_post(App $a)
@@ -41,51 +31,54 @@ function crepair_post(App $a)
 
        $contact = null;
        if ($cid) {
-               $contact = dba::selectFirst('contact', [], ['id' => $cid, 'uid' => local_user()]);
+               $contact = DBA::selectFirst('contact', [], ['id' => $cid, 'uid' => local_user()]);
        }
 
-       if (!DBM::is_result($contact)) {
+       if (!DBA::isResult($contact)) {
                return;
        }
 
-       $name        = defaults($_POST, 'name'       , $contact['name']);
-       $nick        = defaults($_POST, 'nick'       , '');
-       $url         = defaults($_POST, 'url'        , '');
-       $request     = defaults($_POST, 'request'    , '');
-       $confirm     = defaults($_POST, 'confirm'    , '');
-       $notify      = defaults($_POST, 'notify'     , '');
-       $poll        = defaults($_POST, 'poll'       , '');
-       $attag       = defaults($_POST, 'attag'      , '');
-       $photo       = defaults($_POST, 'photo'      , '');
-       $remote_self = defaults($_POST, 'remote_self', false);
-       $nurl        = normalise_link($url);
-
-       $r = q("UPDATE `contact` SET `name` = '%s', `nick` = '%s', `url` = '%s', `nurl` = '%s', `request` = '%s', `confirm` = '%s', `notify` = '%s', `poll` = '%s', `attag` = '%s' , `remote_self` = %d
-               WHERE `id` = %d AND `uid` = %d",
-               dbesc($name),
-               dbesc($nick),
-               dbesc($url),
-               dbesc($nurl),
-               dbesc($request),
-               dbesc($confirm),
-               dbesc($notify),
-               dbesc($poll),
-               dbesc($attag),
-               intval($remote_self),
-               intval($contact['id']),
-               local_user()
+       $name        = ($_POST['name']        ?? '') ?: $contact['name'];
+       $nick        =  $_POST['nick']        ?? '';
+       $url         =  $_POST['url']         ?? '';
+       $alias       =  $_POST['alias']       ?? '';
+       $request     =  $_POST['request']     ?? '';
+       $confirm     =  $_POST['confirm']     ?? '';
+       $notify      =  $_POST['notify']      ?? '';
+       $poll        =  $_POST['poll']        ?? '';
+       $attag       =  $_POST['attag']       ?? '';
+       $photo       =  $_POST['photo']       ?? '';
+       $remote_self =  $_POST['remote_self'] ?? false;
+       $nurl        = Strings::normaliseLink($url);
+
+       $r = DBA::update(
+               'contact',
+               [
+                       'name'        => $name,
+                       'nick'        => $nick,
+                       'url'         => $url,
+                       'nurl'        => $nurl,
+                       'alias'       => $alias,
+                       'request'     => $request,
+                       'confirm'     => $confirm,
+                       'notify'      => $notify,
+                       'poll'        => $poll,
+                       'attag'       => $attag,
+                       'remote_self' => $remote_self,
+               ],
+               ['id' => $contact['id'], 'uid' => local_user()]
        );
 
        if ($photo) {
-               logger('mod-crepair: updating photo from ' . $photo);
+               Logger::log('mod-crepair: updating photo from ' . $photo);
 
-               Contact::updateAvatar($photo, local_user(), $contact['id']);
+               Model\Contact::updateAvatar($photo, local_user(), $contact['id']);
        }
 
        if ($r) {
-               info(t('Contact settings applied.') . EOL);
+               info(L10n::t('Contact settings applied.') . EOL);
        } else {
-               notice(t('Contact update failed.') . EOL);
+               notice(L10n::t('Contact update failed.') . EOL);
        }
 
        return;
@@ -94,76 +87,86 @@ function crepair_post(App $a)
 function crepair_content(App $a)
 {
        if (!local_user()) {
-               notice(t('Permission denied.') . EOL);
+               notice(L10n::t('Permission denied.') . EOL);
                return;
        }
 
        $cid = (($a->argc > 1) ? intval($a->argv[1]) : 0);
 
-               $contact = null;
+       $contact = null;
        if ($cid) {
-               $contact = dba::selectFirst('contact', [], ['id' => $cid, 'uid' => local_user()]);
+               $contact = DBA::selectFirst('contact', [], ['id' => $cid, 'uid' => local_user()]);
        }
 
-       if (!DBM::is_result($contact)) {
-               notice(t('Contact not found.') . EOL);
+       if (!DBA::isResult($contact)) {
+               notice(L10n::t('Contact not found.') . EOL);
                return;
        }
 
-       $warning = t('<strong>WARNING: This is highly advanced</strong> and if you enter incorrect information your communications with this contact may stop working.');
-       $info = t('Please use your browser \'Back\' button <strong>now</strong> if you are uncertain what to do on this page.');
+       if (empty($a->page['aside'])) {
+               $a->page['aside'] = '';
+       }
+
+       if (DBA::isResult($contact)) {
+               $a->data['contact'] = $contact;
+               Model\Profile::load($a, "", 0, Model\Contact::getDetailsByURL($contact["url"]));
+       }
+
+       $warning = L10n::t('<strong>WARNING: This is highly advanced</strong> and if you enter incorrect information your communications with this contact may stop working.');
+       $info = L10n::t('Please use your browser \'Back\' button <strong>now</strong> if you are uncertain what to do on this page.');
 
-       $returnaddr = "contacts/$cid";
+       $returnaddr = "contact/$cid";
 
        $allow_remote_self = Config::get('system', 'allow_users_remote_self');
 
        // Disable remote self for everything except feeds.
        // There is an issue when you repeat an item from maybe twitter and you got comments from friendica and twitter
        // Problem is, you couldn't reply to both networks.
-       if (!in_array($contact['network'], array(NETWORK_FEED, NETWORK_DFRN, NETWORK_DIASPORA))) {
+       if (!in_array($contact['network'], [Protocol::FEED, Protocol::DFRN, Protocol::DIASPORA, Protocol::TWITTER])) {
                $allow_remote_self = false;
        }
 
-       if ($contact['network'] == NETWORK_FEED) {
-               $remote_self_options = array('0' => t('No mirroring'), '1' => t('Mirror as forwarded posting'), '2' => t('Mirror as my own posting'));
+       if ($contact['network'] == Protocol::FEED) {
+               $remote_self_options = ['0' => L10n::t('No mirroring'), '1' => L10n::t('Mirror as forwarded posting'), '2' => L10n::t('Mirror as my own posting')];
        } else {
-               $remote_self_options = array('0' => t('No mirroring'), '2' => t('Mirror as my own posting'));
+               $remote_self_options = ['0' => L10n::t('No mirroring'), '2' => L10n::t('Mirror as my own posting')];
        }
 
-       $update_profile = in_array($contact['network'], array(NETWORK_DFRN, NETWORK_DIASPORA, NETWORK_OSTATUS));
+       $update_profile = in_array($contact['network'], Protocol::FEDERATED);
 
-       $tab_str = contacts_tab($a, $contact['id'], 5);
+       $tab_str = Module\Contact::getTabsHTML($a, $contact, 6);
 
-       $tpl = get_markup_template('crepair.tpl');
-       $o = replace_macros($tpl, array(
+       $tpl = Renderer::getMarkupTemplate('crepair.tpl');
+       $o = Renderer::replaceMacros($tpl, [
                '$tab_str'        => $tab_str,
                '$warning'        => $warning,
                '$info'           => $info,
                '$returnaddr'     => $returnaddr,
-               '$return'         => t('Return to contact editor'),
+               '$return'         => L10n::t('Return to contact editor'),
                '$update_profile' => $update_profile,
-               '$udprofilenow'   => t('Refetch contact data'),
+               '$udprofilenow'   => L10n::t('Refetch contact data'),
                '$contact_id'     => $contact['id'],
-               '$lbl_submit'     => t('Submit'),
-               '$label_remote_self' => t('Remote Self'),
+               '$lbl_submit'     => L10n::t('Submit'),
+               '$label_remote_self' => L10n::t('Remote Self'),
                '$allow_remote_self' => $allow_remote_self,
-               '$remote_self' => array('remote_self',
-                       t('Mirror postings from this contact'),
+               '$remote_self' => ['remote_self',
+                       L10n::t('Mirror postings from this contact'),
                        $contact['remote_self'],
-                       t('Mark this contact as remote_self, this will cause friendica to repost new entries from this contact.'),
+                       L10n::t('Mark this contact as remote_self, this will cause friendica to repost new entries from this contact.'),
                        $remote_self_options
-               ),
-
-               '$name'         => array('name', t('Name') , htmlentities($contact['name'])),
-               '$nick'         => array('nick', t('Account Nickname'), htmlentities($contact['nick'])),
-               '$attag'        => array('attag', t('@Tagname - overrides Name/Nickname'), $contact['attag']),
-               '$url'          => array('url', t('Account URL'), $contact['url']),
-               '$request'      => array('request', t('Friend Request URL'), $contact['request']),
-               'confirm'       => array('confirm', t('Friend Confirm URL'), $contact['confirm']),
-               'notify'        => array('notify', t('Notification Endpoint URL'), $contact['notify']),
-               'poll'          => array('poll', t('Poll/Feed URL'), $contact['poll']),
-               'photo'         => array('photo', t('New photo from this URL'), ''),
-       ));
+               ],
+
+               '$name'         => ['name', L10n::t('Name') , $contact['name']],
+               '$nick'         => ['nick', L10n::t('Account Nickname'), $contact['nick']],
+               '$attag'        => ['attag', L10n::t('@Tagname - overrides Name/Nickname'), $contact['attag']],
+               '$url'          => ['url', L10n::t('Account URL'), $contact['url']],
+               '$alias'        => ['alias', L10n::t('Account URL Alias'), $contact['alias']],
+               '$request'      => ['request', L10n::t('Friend Request URL'), $contact['request']],
+               'confirm'       => ['confirm', L10n::t('Friend Confirm URL'), $contact['confirm']],
+               'notify'        => ['notify', L10n::t('Notification Endpoint URL'), $contact['notify']],
+               'poll'          => ['poll', L10n::t('Poll/Feed URL'), $contact['poll']],
+               'photo'         => ['photo', L10n::t('New photo from this URL'), ''],
+       ]);
 
        return $o;
 }