mirror of
https://github.com/superseriousbusiness/gotosocial.git
synced 2024-12-22 10:12:11 +00:00
23fc70f4e6
* add support for extracting Updated field from Statusable implementers * add support for status edits in the database, and update status dereferencer to handle them * remove unused AdditionalInfo{}.CreatedAt * remove unused AdditionalEmojiInfo{}.CreatedAt * update new mention creation to use status.UpdatedAt * remove mention.UpdatedAt, fixes related to NewULIDFromTime() change * add migration to remove Mention{}.UpdatedAt field * add migration to add the StatusEdit{} table * start adding tests, add delete function for status edits * add more of status edit migrations, fill in more of the necessary edit delete functionality * remove unused function * allow generating gotosocial compatible ulid via CLI with `go run ./cmd/gen-ulid` * add StatusEdit{} test models * fix new statusedits sql * use model instead of table name * actually remove the Mention.UpdatedAt field... * fix tests now new models are added, add more status edit DB tests * fix panic wording * add test for deleting status edits * don't automatically set `updated_at` field on updated statuses * flesh out more of the dereferencer status edit tests, ensure updated at field set on outgoing AS statuses * remove media_attachments.updated_at column * fix up more tests, further complete the dereferencer status edit tests * update more status serialization tests not expecting 'updated' AS property * gah!! json serialization tests!! * undo some gtscontext wrapping changes * more serialization test fixing 🥲 * more test fixing, ensure the edit.status_id field is actually set 🤦 * fix status edit test * grrr linter * add edited_at field to apimodel status * remove the choice of paging on the timeline public filtered test (otherwise it needs updating every time you add statuses ...) * ensure that status.updated_at always fits chronologically * fix more serialization tests ... * add more code comments * fix envparsing * update swagger file * properly handle media description changes during status edits * slight formatting tweak * code comment |
||
---|---|---|
.. | ||
account.go | ||
accountnote.go | ||
accountsettings.go | ||
accountstats.go | ||
adminaction.go | ||
advancedmigration.go | ||
application.go | ||
block.go | ||
client.go | ||
common.go | ||
conversation.go | ||
domainallow.go | ||
domainblock.go | ||
domainpermission.go | ||
domainpermissiondraft.go | ||
domainpermissionexclude.go | ||
emaildomainblock.go | ||
emoji.go | ||
emojicategory.go | ||
filter.go | ||
follow.go | ||
followrequest.go | ||
headerfilter.go | ||
instance.go | ||
interaction.go | ||
interactionpolicy.go | ||
list.go | ||
marker.go | ||
mediaattachment.go | ||
mention.go | ||
move.go | ||
notification.go | ||
poll.go | ||
README.md | ||
report.go | ||
routersession.go | ||
rule.go | ||
sinbinstatus.go | ||
status.go | ||
statusbookmark.go | ||
statusedit.go | ||
statusfave.go | ||
statusmute.go | ||
tag.go | ||
thread.go | ||
threadmute.go | ||
token.go | ||
tombstone.go | ||
user.go | ||
usermute.go | ||
workertask.go |
A note on when we should set data structures linked to objects in the database to use the
bun nullzero
tag -- this should only be done if the member type is a pointer, or if the
this primitive type is literally invalid with an empty value (e.g. media IDs which when
empty signifies a null database value, compared to say an account note which when empty
could mean either an empty note OR null database value).
Obviously it is a little more complex than this in practice, but keep it in mind!