friendica/mod/fsuggest.php

97 lines
2.5 KiB
PHP
Raw Normal View History

2011-06-27 07:57:08 +02:00
<?php
/**
* @file mod/fsuggest.php
*/
use Friendica\App;
2018-03-03 00:41:24 +01:00
use Friendica\Core\ACL;
2017-11-05 13:15:53 +01:00
use Friendica\Core\Worker;
use Friendica\Database\DBA;
use Friendica\DI;
use Friendica\Util\DateTimeFormat;
use Friendica\Util\Strings;
use Friendica\Worker\Delivery;
2018-01-22 13:29:50 +01:00
function fsuggest_post(App $a)
{
2019-05-19 10:54:26 +02:00
if (!local_user()) {
2011-06-27 07:57:08 +02:00
return;
}
if ($a->argc != 2) {
2011-06-27 07:57:08 +02:00
return;
}
2011-06-27 07:57:08 +02:00
$contact_id = intval($a->argv[1]);
2019-05-19 10:54:26 +02:00
if (empty($contact_id)) {
return;
}
2011-06-27 07:57:08 +02:00
// We do query the "uid" as well to ensure that it is our contact
if (!DBA::exists('contact', ['id' => $contact_id, 'uid' => local_user()])) {
notice(DI::l10n()->t('Contact not found.') . EOL);
2011-06-27 07:57:08 +02:00
return;
}
$suggest_contact_id = intval($_POST['suggest']);
if (empty($suggest_contact_id)) {
2019-05-19 10:54:26 +02:00
return;
}
2011-06-27 07:57:08 +02:00
// We do query the "uid" as well to ensure that it is our contact
$contact = DBA::selectFirst('contact', ['name', 'url', 'request', 'avatar'], ['id' => $suggest_contact_id, 'uid' => local_user()]);
if (!DBA::isResult($contact)) {
notice(DI::l10n()->t('Suggested contact not found.') . EOL);
2019-05-19 10:54:26 +02:00
return;
}
2011-06-27 07:57:08 +02:00
$note = Strings::escapeHtml(trim($_POST['note'] ?? ''));
2019-05-19 10:54:26 +02:00
$fields = ['uid' => local_user(),'cid' => $contact_id, 'name' => $contact['name'],
'url' => $contact['url'], 'request' => $contact['request'],
'photo' => $contact['avatar'], 'note' => $note, 'created' => DateTimeFormat::utcNow()];
2019-05-19 10:54:26 +02:00
DBA::insert('fsuggest', $fields);
2011-06-27 07:57:08 +02:00
Worker::add(PRIORITY_HIGH, 'Notifier', Delivery::SUGGESTION, DBA::lastInsertId());
2019-05-19 10:54:26 +02:00
info(DI::l10n()->t('Friend suggestion sent.') . EOL);
}
2011-06-27 07:57:08 +02:00
function fsuggest_content(App $a)
{
if (! local_user()) {
notice(DI::l10n()->t('Permission denied.') . EOL);
2011-06-27 07:57:08 +02:00
return;
}
if ($a->argc != 2) {
2011-06-27 07:57:08 +02:00
return;
}
2011-06-27 07:57:08 +02:00
$contact_id = intval($a->argv[1]);
$contact = DBA::selectFirst('contact', [], ['id' => $contact_id, 'uid' => local_user()]);
if (! DBA::isResult($contact)) {
notice(DI::l10n()->t('Contact not found.') . EOL);
2011-06-27 07:57:08 +02:00
return;
}
$o = '<h3>' . DI::l10n()->t('Suggest Friends') . '</h3>';
2011-06-27 07:57:08 +02:00
$o .= '<div id="fsuggest-desc" >' . DI::l10n()->t('Suggest a friend for %s', $contact['name']) . '</div>';
2011-06-27 07:57:08 +02:00
2011-06-27 12:09:45 +02:00
$o .= '<form id="fsuggest-form" action="fsuggest/' . $contact_id . '" method="post" >';
2011-06-27 07:57:08 +02:00
2018-03-03 00:41:24 +01:00
$o .= ACL::getSuggestContactSelectHTML(
'suggest',
'suggest-select',
2018-02-26 01:47:10 +01:00
['size' => 4, 'exclude' => $contact_id, 'networks' => 'DFRN_ONLY', 'single' => true]
);
2011-06-27 07:57:08 +02:00
$o .= '<div id="fsuggest-submit-wrapper"><input id="fsuggest-submit" type="submit" name="submit" value="' . DI::l10n()->t('Submit') . '" /></div>';
2011-06-27 07:57:08 +02:00
$o .= '</form>';
return $o;
}