2011-04-13 06:25:00 +02:00
|
|
|
<?php
|
2018-01-15 03:22:39 +01:00
|
|
|
/**
|
|
|
|
* @file mod/profperm.php
|
|
|
|
*/
|
2017-04-30 06:07:00 +02:00
|
|
|
use Friendica\App;
|
2017-11-07 03:22:52 +01:00
|
|
|
use Friendica\Core\Config;
|
2018-08-11 22:40:44 +02:00
|
|
|
use Friendica\Core\Protocol;
|
2018-11-06 03:06:26 +01:00
|
|
|
use Friendica\Content\Text\HTML;
|
2018-07-21 14:40:21 +02:00
|
|
|
use Friendica\Database\DBA;
|
2020-01-18 16:50:57 +01:00
|
|
|
use Friendica\DI;
|
2018-01-15 03:38:26 +01:00
|
|
|
use Friendica\Model\Profile;
|
2017-04-30 06:07:00 +02:00
|
|
|
|
2018-01-15 03:22:39 +01:00
|
|
|
function profperm_init(App $a)
|
|
|
|
{
|
2018-08-19 03:52:21 +02:00
|
|
|
if (!local_user()) {
|
2011-04-13 06:25:00 +02:00
|
|
|
return;
|
2016-12-20 11:56:34 +01:00
|
|
|
}
|
2011-04-13 06:25:00 +02:00
|
|
|
|
|
|
|
$which = $a->user['nickname'];
|
2014-03-11 23:52:32 +01:00
|
|
|
$profile = $a->argv[1];
|
2011-04-13 06:25:00 +02:00
|
|
|
|
2018-01-15 03:22:39 +01:00
|
|
|
Profile::load($a, $which, $profile);
|
2011-04-13 06:25:00 +02:00
|
|
|
}
|
|
|
|
|
2016-02-07 15:11:34 +01:00
|
|
|
|
2017-01-09 13:14:55 +01:00
|
|
|
function profperm_content(App $a) {
|
2011-04-13 06:25:00 +02:00
|
|
|
|
2018-08-19 03:52:21 +02:00
|
|
|
if (!local_user()) {
|
2020-01-18 20:52:34 +01:00
|
|
|
notice(DI::l10n()->t('Permission denied') . EOL);
|
2011-04-13 06:25:00 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-08-11 22:40:44 +02:00
|
|
|
if ($a->argc < 2) {
|
2020-01-18 20:52:34 +01:00
|
|
|
notice(DI::l10n()->t('Invalid profile identifier.') . EOL );
|
2011-04-13 06:25:00 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2018-02-12 03:25:09 +01:00
|
|
|
$o = '';
|
|
|
|
|
2011-06-30 05:42:16 +02:00
|
|
|
// Switch to text mod interface if we have more than 'n' contacts or group members
|
|
|
|
|
2020-01-18 16:50:57 +01:00
|
|
|
$switchtotext = DI::pConfig()->get(local_user(),'system','groupedit_image_limit');
|
2017-11-07 23:15:59 +01:00
|
|
|
if (is_null($switchtotext)) {
|
2020-01-19 21:21:13 +01:00
|
|
|
$switchtotext = DI::config()->get('system','groupedit_image_limit', 400);
|
2017-11-07 23:15:59 +01:00
|
|
|
}
|
2011-06-30 05:42:16 +02:00
|
|
|
|
2018-08-19 03:52:21 +02:00
|
|
|
if (($a->argc > 2) && intval($a->argv[1]) && intval($a->argv[2])) {
|
2014-03-11 23:52:32 +01:00
|
|
|
$r = q("SELECT `id` FROM `contact` WHERE `blocked` = 0 AND `pending` = 0 AND `self` = 0
|
2015-04-11 22:14:56 +02:00
|
|
|
AND `network` = '%s' AND `id` = %d AND `uid` = %d LIMIT 1",
|
2018-08-11 22:40:44 +02:00
|
|
|
DBA::escape(Protocol::DFRN),
|
2011-04-13 06:25:00 +02:00
|
|
|
intval($a->argv[2]),
|
|
|
|
intval(local_user())
|
|
|
|
);
|
2018-08-11 22:40:44 +02:00
|
|
|
|
|
|
|
if (DBA::isResult($r)) {
|
2011-04-13 06:25:00 +02:00
|
|
|
$change = intval($a->argv[2]);
|
2018-08-11 22:40:44 +02:00
|
|
|
}
|
2011-04-13 06:25:00 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-08-11 22:40:44 +02:00
|
|
|
if (($a->argc > 1) && (intval($a->argv[1]))) {
|
2011-04-13 06:25:00 +02:00
|
|
|
$r = q("SELECT * FROM `profile` WHERE `id` = %d AND `uid` = %d AND `is-default` = 0 LIMIT 1",
|
|
|
|
intval($a->argv[1]),
|
|
|
|
intval(local_user())
|
|
|
|
);
|
2018-08-19 03:52:21 +02:00
|
|
|
if (!DBA::isResult($r)) {
|
2020-01-18 20:52:34 +01:00
|
|
|
notice(DI::l10n()->t('Invalid profile identifier.') . EOL );
|
2011-04-13 06:25:00 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
$profile = $r[0];
|
|
|
|
|
|
|
|
$r = q("SELECT * FROM `contact` WHERE `uid` = %d AND `profile-id` = %d",
|
|
|
|
intval(local_user()),
|
|
|
|
intval($a->argv[1])
|
|
|
|
);
|
|
|
|
|
2018-01-15 14:05:12 +01:00
|
|
|
$ingroup = [];
|
2018-07-21 14:46:04 +02:00
|
|
|
if (DBA::isResult($r))
|
2017-03-21 17:02:59 +01:00
|
|
|
foreach($r as $member)
|
2011-04-13 06:25:00 +02:00
|
|
|
$ingroup[] = $member['id'];
|
|
|
|
|
|
|
|
$members = $r;
|
|
|
|
|
2018-08-19 03:52:21 +02:00
|
|
|
if (!empty($change)) {
|
|
|
|
if (in_array($change,$ingroup)) {
|
2014-03-11 23:52:32 +01:00
|
|
|
q("UPDATE `contact` SET `profile-id` = 0 WHERE `id` = %d AND `uid` = %d",
|
2011-04-13 06:25:00 +02:00
|
|
|
intval($change),
|
|
|
|
intval(local_user())
|
|
|
|
);
|
|
|
|
}
|
|
|
|
else {
|
2014-03-11 23:52:32 +01:00
|
|
|
q("UPDATE `contact` SET `profile-id` = %d WHERE `id` = %d AND `uid` = %d",
|
2011-04-13 06:25:00 +02:00
|
|
|
intval($a->argv[1]),
|
|
|
|
intval($change),
|
|
|
|
intval(local_user())
|
|
|
|
);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
$r = q("SELECT * FROM `contact` WHERE `uid` = %d AND `profile-id` = %d",
|
|
|
|
intval(local_user()),
|
|
|
|
intval($a->argv[1])
|
|
|
|
);
|
|
|
|
|
|
|
|
$members = $r;
|
|
|
|
|
2018-01-15 14:05:12 +01:00
|
|
|
$ingroup = [];
|
2018-07-21 14:46:04 +02:00
|
|
|
if (DBA::isResult($r))
|
2017-03-21 17:02:59 +01:00
|
|
|
foreach($r as $member)
|
2011-04-13 06:25:00 +02:00
|
|
|
$ingroup[] = $member['id'];
|
|
|
|
}
|
|
|
|
|
2020-01-18 20:52:34 +01:00
|
|
|
$o .= '<h2>' . DI::l10n()->t('Profile Visibility Editor') . '</h2>';
|
2011-04-13 06:25:00 +02:00
|
|
|
|
2020-01-18 20:52:34 +01:00
|
|
|
$o .= '<h3>' . DI::l10n()->t('Profile') . ' \'' . $profile['profile-name'] . '\'</h3>';
|
2011-04-13 06:25:00 +02:00
|
|
|
|
2020-01-18 20:52:34 +01:00
|
|
|
$o .= '<div id="prof-edit-desc">' . DI::l10n()->t('Click on a contact to add or remove.') . '</div>';
|
2011-04-13 06:25:00 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
$o .= '<div id="prof-update-wrapper">';
|
2018-08-19 03:52:21 +02:00
|
|
|
if (!empty($change))
|
2011-04-13 06:25:00 +02:00
|
|
|
$o = '';
|
2017-01-09 13:14:55 +01:00
|
|
|
|
2011-10-04 18:10:57 +02:00
|
|
|
$o .= '<div id="prof-members-title">';
|
2020-01-18 20:52:34 +01:00
|
|
|
$o .= '<h3>' . DI::l10n()->t('Visible To') . '</h3>';
|
2011-10-04 18:10:57 +02:00
|
|
|
$o .= '</div>';
|
|
|
|
$o .= '<div id="prof-members">';
|
2011-06-30 05:42:16 +02:00
|
|
|
|
|
|
|
$textmode = (($switchtotext && (count($members) > $switchtotext)) ? true : false);
|
|
|
|
|
2017-03-21 17:02:59 +01:00
|
|
|
foreach($members as $member) {
|
2018-08-19 03:52:21 +02:00
|
|
|
if ($member['url']) {
|
2011-04-13 06:25:00 +02:00
|
|
|
$member['click'] = 'profChangeMember(' . $profile['id'] . ',' . $member['id'] . '); return true;';
|
2018-11-06 03:06:26 +01:00
|
|
|
$o .= HTML::micropro($member,true,'mpprof', $textmode);
|
2011-04-13 06:25:00 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
$o .= '</div><div id="prof-members-end"></div>';
|
|
|
|
$o .= '<hr id="prof-separator" />';
|
|
|
|
|
2011-10-04 18:10:57 +02:00
|
|
|
$o .= '<div id="prof-all-contcts-title">';
|
2020-01-18 20:52:34 +01:00
|
|
|
$o .= '<h3>' . DI::l10n()->t("All Contacts \x28with secure profile access\x29") . '</h3>';
|
2011-10-04 18:10:57 +02:00
|
|
|
$o .= '</div>';
|
|
|
|
$o .= '<div id="prof-all-contacts">';
|
2015-04-11 22:14:56 +02:00
|
|
|
|
|
|
|
$r = q("SELECT * FROM `contact` WHERE `uid` = %d AND `blocked` = 0 and `pending` = 0 and `self` = 0
|
|
|
|
AND `network` = '%s' ORDER BY `name` ASC",
|
|
|
|
intval(local_user()),
|
2018-08-11 22:40:44 +02:00
|
|
|
DBA::escape(Protocol::DFRN)
|
2011-04-13 06:25:00 +02:00
|
|
|
);
|
|
|
|
|
2018-07-21 14:46:04 +02:00
|
|
|
if (DBA::isResult($r)) {
|
2011-06-30 05:42:16 +02:00
|
|
|
$textmode = (($switchtotext && (count($r) > $switchtotext)) ? true : false);
|
2017-03-21 17:02:59 +01:00
|
|
|
foreach($r as $member) {
|
2018-08-19 03:52:21 +02:00
|
|
|
if (!in_array($member['id'],$ingroup)) {
|
2011-04-13 06:25:00 +02:00
|
|
|
$member['click'] = 'profChangeMember(' . $profile['id'] . ',' . $member['id'] . '); return true;';
|
2018-11-06 03:06:26 +01:00
|
|
|
$o .= HTML::micropro($member,true,'mpprof',$textmode);
|
2011-04-13 06:25:00 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$o .= '</div><div id="prof-all-contacts-end"></div>';
|
|
|
|
|
2018-08-19 03:52:21 +02:00
|
|
|
if (!empty($change)) {
|
2011-04-13 06:25:00 +02:00
|
|
|
echo $o;
|
2018-12-26 06:40:12 +01:00
|
|
|
exit();
|
2011-04-13 06:25:00 +02:00
|
|
|
}
|
|
|
|
$o .= '</div>';
|
|
|
|
return $o;
|
2016-02-07 15:11:34 +01:00
|
|
|
|
2011-04-13 06:25:00 +02:00
|
|
|
}
|