3 * @copyright Copyright (C) 2010-2021, the Friendica project
5 * @license GNU AGPL version 3 or any later version
7 * This program is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU Affero General Public License as
9 * published by the Free Software Foundation, either version 3 of the
10 * License, or (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU Affero General Public License for more details.
17 * You should have received a copy of the GNU Affero General Public License
18 * along with this program. If not, see <https://www.gnu.org/licenses/>.
22 namespace Friendica\Module\Api\Mastodon;
24 use Friendica\Core\Logger;
25 use Friendica\Core\System;
27 use Friendica\Model\Subscription;
28 use Friendica\Module\BaseApi;
31 * @see https://docs.joinmastodon.org/methods/notifications/push/
33 class PushSubscription extends BaseApi
35 public static function post(array $parameters = [])
37 self::checkAllowedScope(self::SCOPE_PUSH);
38 $uid = self::getCurrentUserID();
39 $application = self::getCurrentApplication();
41 $request = self::getRequest([
47 'application-id' => $application['id'],
49 'endpoint' => $request['subscription']['endpoint'] ?? '',
50 'pubkey' => $request['subscription']['keys']['p256dh'] ?? '',
51 'secret' => $request['subscription']['keys']['auth'] ?? '',
52 'follow' => $request['data']['alerts']['follow'] ?? false,
53 'favourite' => $request['data']['alerts']['favourite'] ?? false,
54 'reblog' => $request['data']['alerts']['reblog'] ?? false,
55 'mention' => $request['data']['alerts']['mention'] ?? false,
56 'poll' => $request['data']['alerts']['poll'] ?? false,
57 'follow_request' => $request['data']['alerts']['follow_request'] ?? false,
58 'status' => $request['data']['alerts']['status'] ?? false,
61 $ret = Subscription::replace($subscription);
63 Logger::info('Subscription stored', ['ret' => $ret, 'subscription' => $subscription]);
65 return DI::mstdnSubscription()->createForApplicationIdAndUserId($application['id'], $uid)->toArray();
68 public static function put(array $parameters = [])
70 self::checkAllowedScope(self::SCOPE_PUSH);
71 $uid = self::getCurrentUserID();
72 $application = self::getCurrentApplication();
74 $request = self::getRequest([
78 $subscription = Subscription::select($application['id'], $uid, ['id']);
79 if (empty($subscription)) {
80 Logger::info('Subscription not found', ['application-id' => $application['id'], 'uid' => $uid]);
81 DI::mstdnError()->RecordNotFound();
85 'follow' => $request['data']['alerts']['follow'] ?? false,
86 'favourite' => $request['data']['alerts']['favourite'] ?? false,
87 'reblog' => $request['data']['alerts']['reblog'] ?? false,
88 'mention' => $request['data']['alerts']['mention'] ?? false,
89 'poll' => $request['data']['alerts']['poll'] ?? false,
90 'follow_request' => $request['data']['alerts']['follow_request'] ?? false,
91 'status' => $request['data']['alerts']['status'] ?? false,
94 $ret = Subscription::update($application['id'], $uid, $fields);
96 Logger::info('Subscription updated', ['result' => $ret, 'application-id' => $application['id'], 'uid' => $uid, 'fields' => $fields]);
98 return DI::mstdnSubscription()->createForApplicationIdAndUserId($application['id'], $uid)->toArray();
101 public static function delete(array $parameters = [])
103 self::checkAllowedScope(self::SCOPE_PUSH);
104 $uid = self::getCurrentUserID();
105 $application = self::getCurrentApplication();
107 $ret = Subscription::delete($application['id'], $uid);
109 Logger::info('Subscription deleted', ['result' => $ret, 'application-id' => $application['id'], 'uid' => $uid]);
111 System::jsonExit([]);
114 public static function rawContent(array $parameters = [])
116 self::checkAllowedScope(self::SCOPE_PUSH);
117 $uid = self::getCurrentUserID();
118 $application = self::getCurrentApplication();
120 if (!Subscription::exists($application['id'], $uid)) {
121 Logger::info('Subscription not found', ['application-id' => $application['id'], 'uid' => $uid]);
122 DI::mstdnError()->RecordNotFound();
125 Logger::info('Fetch subscription', ['application-id' => $application['id'], 'uid' => $uid]);
127 return DI::mstdnSubscription()->createForApplicationIdAndUserId($application['id'], $uid)->toArray();