mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-10-29 19:52:24 -05:00 
			
		
		
		
	* Web Push: add policy column to subscriptions * Web Push: add policy to API * Web Push: test notification policy * go-fmt unrelated file (how did this get thru?)
		
			
				
	
	
		
			168 lines
		
	
	
	
		
			6.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			168 lines
		
	
	
	
		
			6.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // GoToSocial
 | |
| // Copyright (C) GoToSocial Authors admin@gotosocial.org
 | |
| // SPDX-License-Identifier: AGPL-3.0-or-later
 | |
| //
 | |
| // This program is free software: you can redistribute it and/or modify
 | |
| // it under the terms of the GNU Affero General Public License as published by
 | |
| // the Free Software Foundation, either version 3 of the License, or
 | |
| // (at your option) any later version.
 | |
| //
 | |
| // This program is distributed in the hope that it will be useful,
 | |
| // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
| // GNU Affero General Public License for more details.
 | |
| //
 | |
| // You should have received a copy of the GNU Affero General Public License
 | |
| // along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | |
| 
 | |
| package model
 | |
| 
 | |
| // WebPushSubscription represents a subscription to a Web Push server.
 | |
| //
 | |
| // swagger:model webPushSubscription
 | |
| type WebPushSubscription struct {
 | |
| 	// The id of the push subscription in the database.
 | |
| 	ID string `json:"id"`
 | |
| 
 | |
| 	// Where push alerts will be sent to.
 | |
| 	Endpoint string `json:"endpoint"`
 | |
| 
 | |
| 	// The streaming server's VAPID public key.
 | |
| 	ServerKey string `json:"server_key"`
 | |
| 
 | |
| 	// Which alerts should be delivered to the endpoint.
 | |
| 	Alerts WebPushSubscriptionAlerts `json:"alerts"`
 | |
| 
 | |
| 	// Which accounts should generate notifications.
 | |
| 	Policy WebPushNotificationPolicy `json:"policy"`
 | |
| 
 | |
| 	// Whether the subscription uses RFC or pre-RFC Web Push standards.
 | |
| 	// For GotoSocial, this is always true.
 | |
| 	Standard bool `json:"standard"`
 | |
| }
 | |
| 
 | |
| // WebPushSubscriptionAlerts represents the specific events that this Web Push subscription will receive.
 | |
| //
 | |
| // swagger:model webPushSubscriptionAlerts
 | |
| type WebPushSubscriptionAlerts struct {
 | |
| 	// Receive a push notification when someone has followed you?
 | |
| 	Follow bool `json:"follow"`
 | |
| 
 | |
| 	// Receive a push notification when someone has requested to follow you?
 | |
| 	FollowRequest bool `json:"follow_request"`
 | |
| 
 | |
| 	// Receive a push notification when a status you created has been favourited by someone else?
 | |
| 	Favourite bool `json:"favourite"`
 | |
| 
 | |
| 	// Receive a push notification when someone else has mentioned you in a status?
 | |
| 	Mention bool `json:"mention"`
 | |
| 
 | |
| 	// Receive a push notification when a status you created has been boosted by someone else?
 | |
| 	Reblog bool `json:"reblog"`
 | |
| 
 | |
| 	// Receive a push notification when a poll you voted in or created has ended?
 | |
| 	Poll bool `json:"poll"`
 | |
| 
 | |
| 	// Receive a push notification when a subscribed account posts a status?
 | |
| 	Status bool `json:"status"`
 | |
| 
 | |
| 	// Receive a push notification when a status you interacted with has been edited?
 | |
| 	Update bool `json:"update"`
 | |
| 
 | |
| 	// Receive a push notification when a new user has signed up?
 | |
| 	AdminSignup bool `json:"admin.sign_up"`
 | |
| 
 | |
| 	// Receive a push notification when a new report has been filed?
 | |
| 	AdminReport bool `json:"admin.report"`
 | |
| 
 | |
| 	// Receive a push notification when a fave is pending?
 | |
| 	PendingFavourite bool `json:"pending.favourite"`
 | |
| 
 | |
| 	// Receive a push notification when a reply is pending?
 | |
| 	PendingReply bool `json:"pending.reply"`
 | |
| 
 | |
| 	// Receive a push notification when a boost is pending?
 | |
| 	PendingReblog bool `json:"pending.reblog"`
 | |
| }
 | |
| 
 | |
| // WebPushSubscriptionCreateRequest captures params for creating or replacing a Web Push subscription.
 | |
| //
 | |
| // swagger:ignore
 | |
| type WebPushSubscriptionCreateRequest struct {
 | |
| 	Subscription *WebPushSubscriptionRequestSubscription `form:"-" json:"subscription"`
 | |
| 
 | |
| 	SubscriptionEndpoint   *string `form:"subscription[endpoint]" json:"-"`
 | |
| 	SubscriptionKeysAuth   *string `form:"subscription[keys][auth]" json:"-"`
 | |
| 	SubscriptionKeysP256dh *string `form:"subscription[keys][p256dh]" json:"-"`
 | |
| 
 | |
| 	WebPushSubscriptionUpdateRequest
 | |
| }
 | |
| 
 | |
| // WebPushSubscriptionRequestSubscription is the part of a Web Push subscription that is fixed at creation.
 | |
| //
 | |
| // swagger:ignore
 | |
| type WebPushSubscriptionRequestSubscription struct {
 | |
| 	// Endpoint is the URL to which Web Push notifications will be sent.
 | |
| 	Endpoint string `json:"endpoint"`
 | |
| 
 | |
| 	Keys WebPushSubscriptionRequestSubscriptionKeys `json:"keys"`
 | |
| }
 | |
| 
 | |
| // WebPushSubscriptionRequestSubscriptionKeys is the part of a Web Push subscription that contains auth secrets.
 | |
| //
 | |
| // swagger:ignore
 | |
| type WebPushSubscriptionRequestSubscriptionKeys struct {
 | |
| 	// Auth is the auth secret, a Base64 encoded string of 16 bytes of random data.
 | |
| 	Auth string `json:"auth"`
 | |
| 
 | |
| 	// P256dh is the user agent public key, a Base64 encoded string of a public key from an ECDH keypair using the prime256v1 curve.
 | |
| 	P256dh string `json:"p256dh"`
 | |
| }
 | |
| 
 | |
| // WebPushSubscriptionUpdateRequest captures params for updating a Web Push subscription.
 | |
| //
 | |
| // swagger:ignore
 | |
| type WebPushSubscriptionUpdateRequest struct {
 | |
| 	Data *WebPushSubscriptionRequestData `form:"-" json:"data"`
 | |
| 
 | |
| 	DataAlertsFollow           *bool `form:"data[alerts][follow]" json:"-"`
 | |
| 	DataAlertsFollowRequest    *bool `form:"data[alerts][follow_request]" json:"-"`
 | |
| 	DataAlertsFavourite        *bool `form:"data[alerts][favourite]" json:"-"`
 | |
| 	DataAlertsMention          *bool `form:"data[alerts][mention]" json:"-"`
 | |
| 	DataAlertsReblog           *bool `form:"data[alerts][reblog]" json:"-"`
 | |
| 	DataAlertsPoll             *bool `form:"data[alerts][poll]" json:"-"`
 | |
| 	DataAlertsStatus           *bool `form:"data[alerts][status]" json:"-"`
 | |
| 	DataAlertsUpdate           *bool `form:"data[alerts][update]" json:"-"`
 | |
| 	DataAlertsAdminSignup      *bool `form:"data[alerts][admin.sign_up]" json:"-"`
 | |
| 	DataAlertsAdminReport      *bool `form:"data[alerts][admin.report]" json:"-"`
 | |
| 	DataAlertsPendingFavourite *bool `form:"data[alerts][pending.favourite]" json:"-"`
 | |
| 	DataAlertsPendingReply     *bool `form:"data[alerts][pending.reply]" json:"-"`
 | |
| 	DataAlertsPendingReblog    *bool `form:"data[alerts][pending.reblog]" json:"-"`
 | |
| 
 | |
| 	DataPolicy *WebPushNotificationPolicy `form:"data[policy]" json:"-"`
 | |
| }
 | |
| 
 | |
| // WebPushSubscriptionRequestData is the part of a Web Push subscription that can be changed after creation.
 | |
| //
 | |
| // swagger:ignore
 | |
| type WebPushSubscriptionRequestData struct {
 | |
| 	// Alerts selects the specific events that this Web Push subscription will receive.
 | |
| 	Alerts *WebPushSubscriptionAlerts `form:"-" json:"alerts"`
 | |
| 
 | |
| 	// Policy selects which accounts will trigger Web Push notifications.
 | |
| 	Policy *WebPushNotificationPolicy `form:"-" json:"policy"`
 | |
| }
 | |
| 
 | |
| // WebPushNotificationPolicy names sets of accounts that can generate notifications.
 | |
| type WebPushNotificationPolicy string
 | |
| 
 | |
| const (
 | |
| 	// WebPushNotificationPolicyAll allows all accounts to send notifications to the subscribing user.
 | |
| 	WebPushNotificationPolicyAll WebPushNotificationPolicy = "all"
 | |
| 	// WebPushNotificationPolicyFollowed allows accounts followed by the subscribing user to send notifications.
 | |
| 	WebPushNotificationPolicyFollowed WebPushNotificationPolicy = "followed"
 | |
| 	// WebPushNotificationPolicyFollower allows accounts following the subscribing user to send notifications.
 | |
| 	WebPushNotificationPolicyFollower WebPushNotificationPolicy = "follower"
 | |
| 	// WebPushNotificationPolicyNone doesn't allow any acounts to send notifications to the subscribing user.
 | |
| 	WebPushNotificationPolicyNone WebPushNotificationPolicy = "none"
 | |
| )
 |