<?php
-
/**
- * @file mod/dfrn_poll.php
+ * @copyright Copyright (C) 2020, Friendica
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <https://www.gnu.org/licenses/>.
+ *
*/
use Friendica\App;
-use Friendica\Core\Config;
use Friendica\Core\Logger;
-use Friendica\Core\System;
use Friendica\Core\Session;
+use Friendica\Core\System;
use Friendica\Database\DBA;
use Friendica\DI;
use Friendica\Protocol\DFRN;
use Friendica\Protocol\OStatus;
-use Friendica\Util\Network;
use Friendica\Util\Strings;
use Friendica\Util\XML;
$hidewall = false;
if (($dfrn_id === '') && empty($_POST['dfrn_id'])) {
- if (Config::get('system', 'block_public') && !Session::isAuthenticated()) {
+ if (DI::config()->get('system', 'block_public') && !Session::isAuthenticated()) {
throw new \Friendica\Network\HTTPException\ForbiddenException();
}
);
if (DBA::isResult($r)) {
- $s = Network::fetchUrl($r[0]['poll'] . '?dfrn_id=' . $my_id . '&type=profile-check');
+ $s = DI::httpRequest()->fetch($r[0]['poll'] . '?dfrn_id=' . $my_id . '&type=profile-check');
Logger::log("dfrn_poll: old profile returns " . $s, Logger::DATA);
Session::setVisitorsContacts();
if (!$quiet) {
- info(DI::l10n()->t('%1$s welcomes %2$s', $r[0]['username'], $r[0]['name']) . EOL);
+ info(DI::l10n()->t('%1$s welcomes %2$s', $r[0]['username'], $r[0]['name']));
}
// Visitors get 1 day session.
{
$dfrn_id = $_POST['dfrn_id'] ?? '';
$challenge = $_POST['challenge'] ?? '';
- $url = $_POST['url'] ?? '';
$sec = $_POST['sec'] ?? '';
$ptype = $_POST['type'] ?? '';
$perm = ($_POST['perm'] ?? '') ?: 'r';
exit();
}
- $type = $r[0]['type'];
$last_update = $r[0]['last_update'];
DBA::delete('challenge', ['dfrn-id' => $dfrn_id, 'challenge' => $challenge]);
}
$contact = $r[0];
- $owner_uid = $r[0]['uid'];
$contact_id = $r[0]['id'];
- if ($type === 'reputation' && strlen($url)) {
- $r = q("SELECT * FROM `contact` WHERE `url` = '%s' AND `uid` = %d LIMIT 1",
- DBA::escape($url),
- intval($owner_uid)
- );
- $reputation = 0;
- $text = '';
-
- if (DBA::isResult($r)) {
- $reputation = $r[0]['rating'];
- $text = $r[0]['reason'];
-
- if ($r[0]['id'] == $contact_id) { // inquiring about own reputation not allowed
- $reputation = 0;
- $text = '';
- }
+ // Update the writable flag if it changed
+ Logger::debug('post request feed', ['post' => $_POST]);
+ if ($dfrn_version >= 2.21) {
+ if ($perm === 'rw') {
+ $writable = 1;
+ } else {
+ $writable = 0;
}
- echo "<?xml version=\"1.0\" encoding=\"UTF-8\"?>
- <reputation>
- <url>$url</url>
- <rating>$reputation</rating>
- <description>$text</description>
- </reputation>
- ";
- exit();
- // NOTREACHED
- } else {
- // Update the writable flag if it changed
- Logger::log('dfrn_poll: post request feed: ' . print_r($_POST, true), Logger::DATA);
- if ($dfrn_version >= 2.21) {
- if ($perm === 'rw') {
- $writable = 1;
- } else {
- $writable = 0;
- }
-
- if ($writable != $contact['writable']) {
- q("UPDATE `contact` SET `writable` = %d WHERE `id` = %d",
- intval($writable),
- intval($contact_id)
- );
- }
+ if ($writable != $contact['writable']) {
+ q("UPDATE `contact` SET `writable` = %d WHERE `id` = %d",
+ intval($writable),
+ intval($contact_id)
+ );
}
-
- header("Content-type: application/atom+xml");
- $o = DFRN::feed($dfrn_id, $a->argv[1], $last_update, $direction);
- echo $o;
- exit();
}
+
+ header("Content-type: application/atom+xml");
+ $o = DFRN::feed($dfrn_id, $a->argv[1], $last_update, $direction);
+ echo $o;
+ exit();
}
function dfrn_poll_content(App $a)
// URL reply
if ($dfrn_version < 2.2) {
- $s = Network::fetchUrl($r[0]['poll']
- . '?dfrn_id=' . $encrypted_id
- . '&type=profile-check'
- . '&dfrn_version=' . DFRN_PROTOCOL_VERSION
- . '&challenge=' . $challenge
- . '&sec=' . $sec
+ $s = DI::httpRequest()->fetch($r[0]['poll']
+ . '?dfrn_id=' . $encrypted_id
+ . '&type=profile-check'
+ . '&dfrn_version=' . DFRN_PROTOCOL_VERSION
+ . '&challenge=' . $challenge
+ . '&sec=' . $sec
);
} else {
- $s = Network::post($r[0]['poll'], [
- 'dfrn_id' => $encrypted_id,
- 'type' => 'profile-check',
+ $s = DI::httpRequest()->post($r[0]['poll'], [
+ 'dfrn_id' => $encrypted_id,
+ 'type' => 'profile-check',
'dfrn_version' => DFRN_PROTOCOL_VERSION,
- 'challenge' => $challenge,
- 'sec' => $sec
+ 'challenge' => $challenge,
+ 'sec' => $sec
])->getBody();
}
if (strlen($s) && strstr($s, '<?xml')) {
$xml = XML::parseString($s);
- Logger::log('dfrn_poll: profile: parsed xml: ' . print_r($xml, true), Logger::DATA);
+ Logger::debug(' profile: parsed', ['xml' => $xml]);
Logger::log('dfrn_poll: secure profile: challenge: ' . $xml->challenge . ' expecting ' . $hash);
Logger::log('dfrn_poll: secure profile: sec: ' . $xml->sec . ' expecting ' . $sec);
Session::setVisitorsContacts();
if (!$quiet) {
- info(DI::l10n()->t('%1$s welcomes %2$s', $r[0]['username'], $r[0]['name']) . EOL);
+ info(DI::l10n()->t('%1$s welcomes %2$s', $r[0]['username'], $r[0]['name']));
}
// Visitors get 1 day session.
switch ($destination_url) {
case 'profile':
- DI::baseUrl()->redirect('profile/' . $profile . '?tab=profile');
+ DI::baseUrl()->redirect('profile/' . $profile . '/profile');
break;
case 'photos':
DI::baseUrl()->redirect('photos/' . $profile);