diff options
Diffstat (limited to 'mod')
-rw-r--r-- | mod/contacts.php | 2 | ||||
-rw-r--r-- | mod/crepair.php | 105 |
2 files changed, 107 insertions, 0 deletions
diff --git a/mod/contacts.php b/mod/contacts.php index 834b1c63d..ee7177d48 100644 --- a/mod/contacts.php +++ b/mod/contacts.php @@ -272,6 +272,8 @@ function contacts_content(&$a) { '$visit' => t('Visit $name\'s profile'), '$blockunblock' => t('Block/Unblock contact'), '$ignorecont' => t('Ignore contact'), + '$altcrepair' => t('Repair contact URL settings'), + '$lblcrepair' => t("Repair contact URL settings \x28WARNING: Advanced\x29"), '$delete' => t('Delete contact'), '$poll_interval' => contact_poll_interval($r[0]['priority']), '$lastupdtext' => t('Last updated: '), diff --git a/mod/crepair.php b/mod/crepair.php new file mode 100644 index 000000000..617c381f7 --- /dev/null +++ b/mod/crepair.php @@ -0,0 +1,105 @@ +<?php + +function crepair_post(&$a) { + if(! local_user()) + return; + + $cid = (($a->argc > 1) ? intval($a->argv[1]) : 0); + + if($cid) { + $r = q("SELECT * FROM `contact` WHERE `id` = %d AND `uid` = %d LIMIT 1", + intval($cid), + intval(local_user()) + ); + } + + if(! count($r)) + return; + + $contact = $r[0]; + + $nick = ((x($_POST,'nick')) ? $_POST['nick'] : null); + $url = ((x($_POST,'url')) ? $_POST['url'] : null); + $request = ((x($_POST,'request')) ? $_POST['request'] : null); + $confirm = ((x($_POST,'confirm')) ? $_POST['confirm'] : null); + $notify = ((x($_POST,'notify')) ? $_POST['notify'] : null); + $poll = ((x($_POST,'poll')) ? $_POST['poll'] : null); + + + $r = q("UPDATE `contact` SET `nick` = '%s', `url` = '%s', `request` = '%s', `confirm` = '%s', `notify` = '%s', `poll` = '%s' + WHERE `id` = %d AND `uid` = %d LIMIT 1", + dbesc($nick), + dbesc($url), + dbesc($request), + dbesc($confirm), + dbesc($notify), + dbesc($poll), + intval($contact['id']), + local_user() + ); + + if($r) + notice( t('Contact settings applied.') . EOL); + else + notice( t('Contact update failed.') . EOL); + + return; +} + + + +function crepair_content(&$a) { + + if(! local_user()) { + notice( t('Permission denied.') . EOL); + return; + } + + $cid = (($a->argc > 1) ? intval($a->argv[1]) : 0); + + if($cid) { + $r = q("SELECT * FROM `contact` WHERE `id` = %d AND `uid` = %d LIMIT 1", + intval($cid), + intval(local_user()) + ); + } + + if(! count($r)) { + notice( t('Contact not found.') . EOL); + return; + } + + $contact = $r[0]; + + $msg1 = t('Repair Contact Settings'); + + $msg2 = t('<strong>WARNING: This is highly advanced</strong> and if you enter incorrect information your communications with this contact will stop working.'); + $msg3 = t('Please use your browser \'Back\' button <strong>now</strong> if you are uncertain what to do on this page.'); + + $o .= '<h2>' . $msg1 . '</h2>'; + + $o .= '<div class="error-message">' . $msg2 . EOL . EOL. $msg3 . '</div>'; + + $tpl = load_view_file('view/crepair.tpl'); + $o .= replace_macros($tpl, array( + '$label_name' => t('Name'), + '$label_nick' => t('Account 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'), + '$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'], + '$lbl_submit' => t('Submit') + )); + + return $o; + +}
\ No newline at end of file |