Merge pull request #10613 from annando/improved-payload
The push api payload content is improved
This commit is contained in:
commit
f0bb83c225
2 changed files with 60 additions and 23 deletions
|
@ -21,12 +21,16 @@
|
||||||
|
|
||||||
namespace Friendica\Worker;
|
namespace Friendica\Worker;
|
||||||
|
|
||||||
|
use Friendica\Content\Text\BBCode;
|
||||||
|
use Friendica\Content\Text\Plaintext;
|
||||||
use Friendica\Core\Logger;
|
use Friendica\Core\Logger;
|
||||||
use Friendica\Database\DBA;
|
use Friendica\Database\DBA;
|
||||||
use Friendica\DI;
|
use Friendica\DI;
|
||||||
use Friendica\Model\Contact;
|
use Friendica\Model\Contact;
|
||||||
|
use Friendica\Model\Notification;
|
||||||
|
use Friendica\Model\Post;
|
||||||
use Friendica\Model\Subscription as ModelSubscription;
|
use Friendica\Model\Subscription as ModelSubscription;
|
||||||
use Friendica\Util\DateTimeFormat;
|
use Friendica\Model\User;
|
||||||
use Minishlink\WebPush\WebPush;
|
use Minishlink\WebPush\WebPush;
|
||||||
use Minishlink\WebPush\Subscription;
|
use Minishlink\WebPush\Subscription;
|
||||||
|
|
||||||
|
@ -48,32 +52,60 @@ class PushSubscription
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!empty($notification['uri-id'])) {
|
$application_token = DBA::selectFirst('application-token', [], ['application-id' => $subscription['application-id'], 'uid' => $subscription['uid']]);
|
||||||
$notify = DBA::selectFirst('notify', ['msg'], ['uri-id' => $notification['target-uri-id']]);
|
if (empty($application_token)) {
|
||||||
|
Logger::info('Application token not found', ['application' => $subscription['application-id']]);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$user = User::getById($notification['uid']);
|
||||||
|
if (empty($user)) {
|
||||||
|
Logger::info('User not found', ['application' => $subscription['uid']]);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$l10n = DI::l10n()->withLang($user['language']);
|
||||||
|
|
||||||
|
$type = Notification::getType($notification);
|
||||||
|
|
||||||
if (!empty($notification['actor-id'])) {
|
if (!empty($notification['actor-id'])) {
|
||||||
$actor = Contact::getById($notification['actor-id']);
|
$actor = Contact::getById($notification['actor-id']);
|
||||||
}
|
}
|
||||||
|
|
||||||
$push = [
|
$body = '';
|
||||||
'subscription' => Subscription::create([
|
|
||||||
'endpoint' => $subscription['endpoint'],
|
if (!empty($notification['target-uri-id'])) {
|
||||||
'publicKey' => $subscription['pubkey'],
|
$post = Post::selectFirst([], ['uri-id' => $notification['target-uri-id'], 'uid' => [0, $notification['uid']]]);
|
||||||
'authToken' => $subscription['secret'],
|
if (!empty($post['body'])) {
|
||||||
]),
|
$body = BBCode::toPlaintext($post['body'], false);
|
||||||
// @todo Check if we are supposed to transmit a payload at all
|
$body = Plaintext::shorten($body, 160, $notification['uid']);
|
||||||
'payload' => json_encode([
|
}
|
||||||
'title' => 'Friendica',
|
}
|
||||||
'body' => $notify['msg'] ?? '',
|
|
||||||
'icon' => $actor['thumb'] ?? '',
|
// @todo Add a meaningful title here, see the functionality in enotify.php
|
||||||
'image' => '',
|
$title = '';
|
||||||
'badge' => DI::baseUrl()->get() . '/images/friendica-192.png',
|
|
||||||
'tag' => $notification['parent-uri-id'] ?? '',
|
$push = Subscription::create([
|
||||||
'timestamp' => DateTimeFormat::utc($notification['created'], DateTimeFormat::JSON),
|
'contentEncoding' => 'aesgcm',
|
||||||
]),
|
'endpoint' => $subscription['endpoint'],
|
||||||
|
'keys' => [
|
||||||
|
'p256dh' => $subscription['pubkey'],
|
||||||
|
'auth' => $subscription['secret']
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
|
||||||
|
$payload = [
|
||||||
|
'access_token' => $application_token['access_token'],
|
||||||
|
'preferred_locale' => $user['language'],
|
||||||
|
'notification_id' => $nid,
|
||||||
|
'notification_type' => $type,
|
||||||
|
'icon' => $actor['thumb'] ?? '',
|
||||||
|
'title' => $title ?: $l10n->t('Notification from Friendica'),
|
||||||
|
'body' => $body ?: $l10n->t('Empty Post'),
|
||||||
];
|
];
|
||||||
|
|
||||||
|
Logger::info('Payload', ['payload' => $payload]);
|
||||||
|
|
||||||
$auth = [
|
$auth = [
|
||||||
'VAPID' => [
|
'VAPID' => [
|
||||||
'subject' => DI::baseUrl()->getHostname(),
|
'subject' => DI::baseUrl()->getHostname(),
|
||||||
|
@ -84,10 +116,7 @@ class PushSubscription
|
||||||
|
|
||||||
$webPush = new WebPush($auth, [], DI::config()->get('system', 'xrd_timeout'));
|
$webPush = new WebPush($auth, [], DI::config()->get('system', 'xrd_timeout'));
|
||||||
|
|
||||||
$report = $webPush->sendOneNotification(
|
$report = $webPush->sendOneNotification($push, json_encode($payload), ['urgency' => 'normal']);
|
||||||
$push['subscription'],
|
|
||||||
$push['payload']
|
|
||||||
);
|
|
||||||
|
|
||||||
$endpoint = $report->getRequest()->getUri()->__toString();
|
$endpoint = $report->getRequest()->getUri()->__toString();
|
||||||
|
|
||||||
|
|
|
@ -10553,6 +10553,14 @@ msgstr ""
|
||||||
msgid "(no subject)"
|
msgid "(no subject)"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
#: src/Worker/PushSubscription.php:100
|
||||||
|
msgid "Notification from Friendica"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
#: src/Worker/PushSubscription.php:101
|
||||||
|
msgid "Empty Post"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
#: view/theme/duepuntozero/config.php:52
|
#: view/theme/duepuntozero/config.php:52
|
||||||
msgid "default"
|
msgid "default"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
Loading…
Reference in a new issue