]> git.mxchange.org Git - friendica.git/blobdiff - mod/crepair.php
added more spaces (CR request)
[friendica.git] / mod / crepair.php
index 1324185342c97382280a473caa9e5d73b27efff2..902a129303972a7e18b7c426f84aff37231c5fc8 100644 (file)
@@ -1,8 +1,11 @@
 <?php
+require_once("include/contact_selectors.php");
+require_once("mod/contacts.php");
 
-function crepair_init(&$a) {
-       if(! local_user())
+function crepair_init(App $a) {
+       if (! local_user()) {
                return;
+       }
 
        $contact_id = 0;
 
@@ -12,7 +15,7 @@ function crepair_init(&$a) {
                        intval(local_user()),
                        intval($contact_id)
                );
-               if(! count($r)) {
+               if (! dbm::is_result($r)) {
                        $contact_id = 0;
                }
        }
@@ -21,20 +24,16 @@ function crepair_init(&$a) {
                $a->page['aside'] = '';
 
        if($contact_id) {
-                       $a->data['contact'] = $r[0];
-                       $o .= '<div class="vcard">';
-                       $o .= '<div class="fn">' . $a->data['contact']['name'] . '</div>';
-                       $o .= '<div id="profile-photo-wrapper"><img class="photo" style="width: 175px; height: 175px;" src="' . $a->data['contact']['photo'] . '" alt="' . $a->data['contact']['name'] . '" /></div>';
-                       $o .= '</div>';
-                       $a->page['aside'] .= $o;
-
-       }       
+               $a->data['contact'] = $r[0];
+               $contact = $r[0];
+               profile_load($a, "", 0, get_contact_details_by_url($contact["url"]));
+       }
 }
 
-
-function crepair_post(&$a) {
-       if(! local_user())
+function crepair_post(App $a) {
+       if (! local_user()) {
                return;
+       }
 
        $cid = (($a->argc > 1) ? intval($a->argv[1]) : 0);
 
@@ -45,8 +44,9 @@ function crepair_post(&$a) {
                );
        }
 
-       if(! count($r))
+       if (! dbm::is_result($r)) {
                return;
+       }
 
        $contact = $r[0];
 
@@ -59,19 +59,21 @@ function crepair_post(&$a) {
        $poll    = ((x($_POST,'poll')) ? $_POST['poll'] : '');
        $attag   = ((x($_POST,'attag')) ? $_POST['attag'] : '');
        $photo   = ((x($_POST,'photo')) ? $_POST['photo'] : '');
-       $remote_self = ((x($_POST,'remote_self')) ? intval($_POST['remote_self']) : 0);
+       $remote_self = ((x($_POST,'remote_self')) ? $_POST['remote_self'] : false);
+       $nurl    = normalise_link($url);
 
-       $r = q("UPDATE `contact` SET `name` = '%s', `nick` = '%s', `url` = '%s', `request` = '%s', `confirm` = '%s', `notify` = '%s', `poll` = '%s', `attag` = '%s', `remote_self` = '%d'
-               WHERE `id` = %d AND `uid` = %d LIMIT 1",
+       $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),
-               $remote_self,
+               intval($remote_self),
                intval($contact['id']),
                local_user()
        );
@@ -80,24 +82,7 @@ function crepair_post(&$a) {
                logger('mod-crepair: updating photo from ' . $photo);
                require_once("include/Photo.php");
 
-               $photos = import_profile_photo($photo,local_user(),$contact['id']);
-
-               $x = q("UPDATE `contact` SET `photo` = '%s',
-                       `thumb` = '%s',
-                       `micro` = '%s',
-                       `name-date` = '%s',
-                       `uri-date` = '%s',
-                       `avatar-date` = '%s'
-                       WHERE `id` = %d LIMIT 1
-                       ",
-                       dbesc($photos[0]),
-                       dbesc($photos[1]),
-                       dbesc($photos[2]),
-                       dbesc(datetime_convert()),
-                       dbesc(datetime_convert()),
-                       dbesc(datetime_convert()),
-                       intval($contact['id'])
-               );
+               update_contact_avatar($photo,local_user(),$contact['id']);
        }
 
        if($r)
@@ -111,9 +96,9 @@ function crepair_post(&$a) {
 
 
 
-function crepair_content(&$a) {
+function crepair_content(App $a) {
 
-       if(! local_user()) {
+       if (! local_user()) {
                notice( t('Permission denied.') . EOL);
                return;
        }
@@ -127,48 +112,68 @@ function crepair_content(&$a) {
                );
        }
 
-       if(! count($r)) {
+       if (! dbm::is_result($r)) {
                notice( t('Contact not found.') . EOL);
                return;
        }
 
        $contact = $r[0];
 
-       $msg1 = t('Repair Contact Settings');
+       $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.');
 
-       $msg2 = t('<strong>WARNING: This is highly advanced</strong> and if you enter incorrect information your communications with this contact may stop working.');
-       $msg3 = t('Please use your browser \'Back\' button <strong>now</strong> if you are uncertain what to do on this page.');
+       $returnaddr = "contacts/$cid";
 
-       $o .= '<h2>' . $msg1 . '</h2>';
+       $allow_remote_self = get_config('system','allow_users_remote_self');
 
-       $o .= '<div class="error-message">' . $msg2 . EOL . EOL. $msg3 . '</div>';
+       // 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)))
+               $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'));
+       else
+               $remote_self_options = array('0'=>t('No mirroring'), '2'=>t('Mirror as my own posting'));
+
+       $update_profile = in_array($contact['network'], array(NETWORK_DFRN, NETWORK_DSPR, NETWORK_OSTATUS));
+
+       $tab_str = contacts_tab($a, $contact['id'], 5);
 
-       $o .= EOL . '<a href="contacts/' . $cid . '">' . t('Return to contact editor') . '</a>' . EOL;
 
        $tpl = get_markup_template('crepair.tpl');
        $o .= replace_macros($tpl, array(
-               '$label_name' => t('Name'),
-               '$label_nick' => t('Account Nickname'),
-               '$label_attag' => t('@Tagname - overrides Name/Nickname'),
-               '$label_url' => t('Account URL'),
-               '$label_request' => t('Friend Request URL'),
-               '$label_confirm' => t('Friend Confirm URL'),
-               '$label_notify' => t('Notification Endpoint URL'),
-               '$label_poll' => t('Poll/Feed URL'),
-               '$label_photo' => t('New photo from this URL'),
+               //'$title'      => t('Repair Contact Settings'),
+               '$tab_str'      => $tab_str,
+               '$warning'      => $warning,
+               '$info'         => $info,
+               '$returnaddr'   => $returnaddr,
+               '$return'       => t('Return to contact editor'),
+               '$update_profile' => update_profile,
+               '$udprofilenow' => t('Refetch contact data'),
+               '$contact_id'   => $contact['id'],
+               '$lbl_submit'   => t('Submit'),
+
                '$label_remote_self' => t('Remote Self'),
-               '$remote_self' => array('remote_self', 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.')),  
-               '$contact_name' => $contact['name'],
-               '$contact_nick' => $contact['nick'],
-               '$contact_id'   => $contact['id'],
-               '$contact_url'  => $contact['url'],
-               '$request'      => $contact['request'],
-               '$confirm'      => $contact['confirm'],
-               '$notify'       => $contact['notify'],
-               '$poll'         => $contact['poll'],
-               '$contact_attag'  => $contact['attag'],
-               '$lbl_submit'   => t('Submit')
-           ));
+               '$allow_remote_self' => $allow_remote_self,
+               '$remote_self' => array('remote_self',
+                                       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.'),
+                                       $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'), ''),
+       ));
 
        return $o;