2023-03-12 15:00:57 +00:00
|
|
|
// 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/>.
|
2021-05-27 14:06:24 +00:00
|
|
|
|
|
|
|
package gtsmodel
|
|
|
|
|
2024-11-27 17:22:45 +00:00
|
|
|
import (
|
|
|
|
"strings"
|
|
|
|
"time"
|
|
|
|
)
|
2021-05-27 14:06:24 +00:00
|
|
|
|
|
|
|
// Notification models an alert/notification sent to an account about something like a reblog, like, new follow request, etc.
|
|
|
|
type Notification struct {
|
2023-08-06 10:22:40 +00:00
|
|
|
ID string `bun:"type:CHAR(26),pk,nullzero,notnull,unique"` // id of this item in the database
|
|
|
|
CreatedAt time.Time `bun:"type:timestamptz,nullzero,notnull,default:current_timestamp"` // when was item created
|
|
|
|
UpdatedAt time.Time `bun:"type:timestamptz,nullzero,notnull,default:current_timestamp"` // when was item last updated
|
|
|
|
NotificationType NotificationType `bun:",nullzero,notnull"` // Type of this notification
|
|
|
|
TargetAccountID string `bun:"type:CHAR(26),nullzero,notnull"` // ID of the account targeted by the notification (ie., who will receive the notification?)
|
|
|
|
TargetAccount *Account `bun:"-"` // Account corresponding to TargetAccountID. Can be nil, always check first + select using ID if necessary.
|
|
|
|
OriginAccountID string `bun:"type:CHAR(26),nullzero,notnull"` // ID of the account that performed the action that created the notification.
|
|
|
|
OriginAccount *Account `bun:"-"` // Account corresponding to OriginAccountID. Can be nil, always check first + select using ID if necessary.
|
|
|
|
StatusID string `bun:"type:CHAR(26),nullzero"` // If the notification pertains to a status, what is the database ID of that status?
|
|
|
|
Status *Status `bun:"-"` // Status corresponding to StatusID. Can be nil, always check first + select using ID if necessary.
|
|
|
|
Read *bool `bun:",nullzero,notnull,default:false"` // Notification has been seen/read
|
2021-05-27 14:06:24 +00:00
|
|
|
}
|
|
|
|
|
2024-11-25 13:48:59 +00:00
|
|
|
// NotificationType describes the
|
|
|
|
// reason/type of this notification.
|
|
|
|
type NotificationType enumType
|
2021-05-27 14:06:24 +00:00
|
|
|
|
|
|
|
const (
|
2024-11-25 13:48:59 +00:00
|
|
|
// Notification Types
|
2024-11-27 17:22:45 +00:00
|
|
|
NotificationUnknown NotificationType = 0 // NotificationUnknown -- unknown notification type, error if this occurs
|
2024-11-25 13:48:59 +00:00
|
|
|
NotificationFollow NotificationType = 1 // NotificationFollow -- someone followed you
|
|
|
|
NotificationFollowRequest NotificationType = 2 // NotificationFollowRequest -- someone requested to follow you
|
|
|
|
NotificationMention NotificationType = 3 // NotificationMention -- someone mentioned you in their status
|
|
|
|
NotificationReblog NotificationType = 4 // NotificationReblog -- someone boosted one of your statuses
|
2024-11-30 20:24:13 +00:00
|
|
|
NotificationFavourite NotificationType = 5 // NotificationFavourite -- someone faved/liked one of your statuses
|
2024-11-25 13:48:59 +00:00
|
|
|
NotificationPoll NotificationType = 6 // NotificationPoll -- a poll you voted in or created has ended
|
|
|
|
NotificationStatus NotificationType = 7 // NotificationStatus -- someone you enabled notifications for has posted a status.
|
2024-11-30 20:24:13 +00:00
|
|
|
NotificationAdminSignup NotificationType = 8 // NotificationAdminSignup -- someone has submitted a new account sign-up to the instance.
|
|
|
|
NotificationPendingFave NotificationType = 9 // NotificationPendingFave -- Someone has faved a status of yours, which requires approval by you.
|
|
|
|
NotificationPendingReply NotificationType = 10 // NotificationPendingReply -- Someone has replied to a status of yours, which requires approval by you.
|
|
|
|
NotificationPendingReblog NotificationType = 11 // NotificationPendingReblog -- Someone has boosted a status of yours, which requires approval by you.
|
|
|
|
NotificationAdminReport NotificationType = 12 // NotificationAdminReport -- someone has submitted a new report to the instance.
|
2024-12-26 01:40:23 +00:00
|
|
|
NotificationTypeNumValues NotificationType = 13 // NotificationTypeNumValues -- 1 + number of max notification type
|
2021-05-27 14:06:24 +00:00
|
|
|
)
|
2024-11-25 13:48:59 +00:00
|
|
|
|
|
|
|
// String returns a stringified, frontend API compatible form of NotificationType.
|
|
|
|
func (t NotificationType) String() string {
|
|
|
|
switch t {
|
|
|
|
case NotificationFollow:
|
|
|
|
return "follow"
|
|
|
|
case NotificationFollowRequest:
|
|
|
|
return "follow_request"
|
|
|
|
case NotificationMention:
|
|
|
|
return "mention"
|
|
|
|
case NotificationReblog:
|
|
|
|
return "reblog"
|
2024-11-30 20:24:13 +00:00
|
|
|
case NotificationFavourite:
|
2024-11-25 13:48:59 +00:00
|
|
|
return "favourite"
|
|
|
|
case NotificationPoll:
|
|
|
|
return "poll"
|
|
|
|
case NotificationStatus:
|
|
|
|
return "status"
|
2024-11-30 20:24:13 +00:00
|
|
|
case NotificationAdminSignup:
|
2024-11-25 13:48:59 +00:00
|
|
|
return "admin.sign_up"
|
|
|
|
case NotificationPendingFave:
|
|
|
|
return "pending.favourite"
|
|
|
|
case NotificationPendingReply:
|
|
|
|
return "pending.reply"
|
|
|
|
case NotificationPendingReblog:
|
|
|
|
return "pending.reblog"
|
2024-11-30 20:24:13 +00:00
|
|
|
case NotificationAdminReport:
|
|
|
|
return "admin.report"
|
2024-11-25 13:48:59 +00:00
|
|
|
default:
|
|
|
|
panic("invalid notification type")
|
|
|
|
}
|
|
|
|
}
|
2024-11-27 17:22:45 +00:00
|
|
|
|
2024-11-28 11:54:22 +00:00
|
|
|
// ParseNotificationType returns a notification type from the given value.
|
|
|
|
func ParseNotificationType(in string) NotificationType {
|
2024-11-27 17:22:45 +00:00
|
|
|
switch strings.ToLower(in) {
|
|
|
|
case "follow":
|
|
|
|
return NotificationFollow
|
|
|
|
case "follow_request":
|
|
|
|
return NotificationFollowRequest
|
|
|
|
case "mention":
|
|
|
|
return NotificationMention
|
|
|
|
case "reblog":
|
|
|
|
return NotificationReblog
|
|
|
|
case "favourite":
|
2024-11-30 20:24:13 +00:00
|
|
|
return NotificationFavourite
|
2024-11-27 17:22:45 +00:00
|
|
|
case "poll":
|
|
|
|
return NotificationPoll
|
|
|
|
case "status":
|
|
|
|
return NotificationStatus
|
|
|
|
case "admin.sign_up":
|
2024-11-30 20:24:13 +00:00
|
|
|
return NotificationAdminSignup
|
2024-11-27 17:22:45 +00:00
|
|
|
case "pending.favourite":
|
|
|
|
return NotificationPendingFave
|
|
|
|
case "pending.reply":
|
|
|
|
return NotificationPendingReply
|
|
|
|
case "pending.reblog":
|
|
|
|
return NotificationPendingReblog
|
2024-11-30 20:24:13 +00:00
|
|
|
case "admin.report":
|
|
|
|
return NotificationAdminReport
|
2024-11-27 17:22:45 +00:00
|
|
|
default:
|
|
|
|
return NotificationUnknown
|
|
|
|
}
|
|
|
|
}
|