X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FModel%2FSubscription.php;h=10a2d9b4d10d1af6b9b0e051b2c5a4db7c6b4e06;hb=e2e95f7d7207830a185d260b07f61c2cd9e7186e;hp=fac585e992bd95849826011d641dfdce1f976039;hpb=167a12ef54c8caa263728a336afde55202067643;p=friendica.git diff --git a/src/Model/Subscription.php b/src/Model/Subscription.php index fac585e992..10a2d9b4d1 100644 --- a/src/Model/Subscription.php +++ b/src/Model/Subscription.php @@ -1,6 +1,6 @@ $applicationid, 'uid' => $uid]); + } + + /** + * Check if a subscription record exists + * + * @param int $applicationid + * @param int $uid + * + * @return bool Does it exist? + */ + public static function exists(int $applicationid, int $uid): bool + { + return DBA::exists('subscription', ['application-id' => $applicationid, 'uid' => $uid]); + } + + /** + * Update a subscription record + * + * @param int $applicationid + * @param int $uid * @param array $fields subscription fields + * @return bool result of update + */ + public static function update(int $applicationid, int $uid, array $fields): bool + { + return DBA::update('subscription', $fields, ['application-id' => $applicationid, 'uid' => $uid]); + } + + /** + * Insert or replace a subscription record * + * @param array $fields subscription fields * @return bool result of replace */ - public static function replace(array $fields) + public static function replace(array $fields): bool { return DBA::replace('subscription', $fields); } /** * Delete a subscription record + * * @param int $applicationid * @param int $uid * @return bool */ - public static function delete(int $applicationid, int $uid) + public static function delete(int $applicationid, int $uid): bool { return DBA::delete('subscription', ['application-id' => $applicationid, 'uid' => $uid]); } /** - * Fetch a VAPID key - * @return string + * Fetch a VAPID keypair + * + * @return array */ - public static function getVapidKey(): string + private static function getKeyPair(): array { $keypair = DI::config()->get('system', 'ec_keypair'); - if (empty($keypair)) { - $keypair = Crypto::newECKeypair(); + if (empty($keypair['publicKey']) || empty($keypair['privateKey'])) { + $keypair = VAPID::createVapidKeys(); DI::config()->set('system', 'ec_keypair', $keypair); } - return $keypair['vapid']; + return $keypair; + } + + /** + * Fetch the public VAPID key + * + * @return string + */ + public static function getPublicVapidKey(): string + { + $keypair = self::getKeyPair(); + return $keypair['publicKey']; + } + + /** + * Fetch the public VAPID key + * + * @return string + */ + public static function getPrivateVapidKey(): string + { + $keypair = self::getKeyPair(); + return $keypair['privateKey']; + } + + /** + * Prepare push notification + * + * @param Notification $Notification + * @return void + */ + public static function pushByNotification(Entity\Notification $notification) + { + $type = NotificationFactory::getType($notification); + + if (DI::notify()->shouldShowOnDesktop($notification, $type)) { + DI::notify()->createFromNotification($notification); + } + + if (empty($type)) { + return; + } + + $subscriptions = DBA::select('subscription', [], ['uid' => $notification->uid, $type => true]); + while ($subscription = DBA::fetch($subscriptions)) { + Logger::info('Push notification', ['id' => $subscription['id'], 'uid' => $subscription['uid'], 'type' => $type]); + Worker::add(Worker::PRIORITY_HIGH, 'PushSubscription', $subscription['id'], $notification->id); + } + DBA::close($subscriptions); } }