gotosocial/internal/gtsmodel/scheduledstatus.go
nicole mikołajczyk 660cf2c94c [feature] scheduled statuses (#4274)
An implementation of [`scheduled_statuses`](https://docs.joinmastodon.org/methods/scheduled_statuses/). Will fix #1006.

this is heavily WIP and I need to reorganize some of the code, working on this made me somehow familiar with the codebase and led to my other recent contributions
i told some fops on fedi i'd work on this so i have no choice but to complete it 🤷‍♀️
btw iirc my avatar presents me working on this branch

Signed-off-by: nicole mikołajczyk <git@mkljczk.pl>
Reviewed-on: https://codeberg.org/superseriousbusiness/gotosocial/pulls/4274
Co-authored-by: nicole mikołajczyk <git@mkljczk.pl>
Co-committed-by: nicole mikołajczyk <git@mkljczk.pl>
2025-08-12 14:05:15 +02:00

65 lines
4.2 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 gtsmodel
import "time"
// ScheduledStatus represents a status that is scheduled to be published at given time by a local user.
type ScheduledStatus struct {
ID string `bun:"type:CHAR(26),pk,nullzero,notnull,unique"` // id of this item in the database
AccountID string `bun:"type:CHAR(26),nullzero,notnull"` // which account scheduled this status
Account *Account `bun:"-"` // Account corresponding to AccountID
ScheduledAt time.Time `bun:"type:timestamptz,nullzero,notnull"` // time at which the status is scheduled
Text string `bun:""` // Text content of the status
Poll ScheduledStatusPoll `bun:",embed:poll_,notnull,nullzero"` //
MediaIDs []string `bun:"attachments,array"` // Database IDs of any media attachments associated with this status
MediaAttachments []*MediaAttachment `bun:"-"` // Attachments corresponding to media IDs
Sensitive *bool `bun:",nullzero,notnull,default:false"` // mark the status as sensitive?
SpoilerText string `bun:""` // Original text of the content warning without formatting
Visibility Visibility `bun:",nullzero,notnull"` // visibility entry for this status
InReplyToID string `bun:"type:CHAR(26),nullzero"` // id of the status this status replies to
Language string `bun:",nullzero"` // what language is this status written in?
ApplicationID string `bun:"type:CHAR(26),nullzero"` // Which application was used to create this status?
Application *Application `bun:"-"` //
LocalOnly *bool `bun:",nullzero,notnull,default:false"` // Whether the status is not federated
ContentType string `bun:",nullzero"` // Content type used to process the original text of the status
InteractionPolicy *InteractionPolicy `bun:""` // InteractionPolicy for this status. If null then the default InteractionPolicy should be assumed for this status's Visibility. Always null for boost wrappers.
Idempotency string `bun:",nullzero"` // Currently unused
}
type ScheduledStatusPoll struct {
Options []string `bun:",nullzero,array"` // The available options for this poll.
ExpiresIn int `bun:",nullzero"` // Duration the poll should be open, in seconds
Multiple *bool `bun:",nullzero,notnull,default:false"` // Is this a multiple choice poll? i.e. can you vote on multiple options.
HideTotals *bool `bun:",nullzero,notnull,default:false"` // Hides vote counts until poll ends.
}
// AttachmentsPopulated returns whether media attachments
// are populated according to current AttachmentIDs.
func (s *ScheduledStatus) AttachmentsPopulated() bool {
if len(s.MediaIDs) != len(s.MediaAttachments) {
// this is the quickest indicator.
return false
}
for i, id := range s.MediaIDs {
if s.MediaAttachments[i].ID != id {
return false
}
}
return true
}