* start work on accounts module * plodding away on the accounts endpoint * groundwork for other account routes * add password validator * validation utils * require account approval flags * comments * comments * go fmt * comments * add distributor stub * rename api to federator * tidy a bit * validate new account requests * rename r router * comments * add domain blocks * add some more shortcuts * add some more shortcuts * check email + username availability * email block checking for signups * chunking away at it * tick off a few more things * some fiddling with tests * add mock package * relocate repo * move mocks around * set app id on new signups * initialize oauth server properly * rename oauth server * proper mocking tests * go fmt ./... * add required fields * change name of func * move validation to account.go * more tests! * add some file utility tools * add mediaconfig * new shortcut * add some more fields * add followrequest model * add notify * update mastotypes * mock out storage interface * start building media interface * start on update credentials * mess about with media a bit more * test image manipulation * media more or less working * account update nearly working * rearranging my package ;) ;) ;) * phew big stuff!!!! * fix type checking * *fiddles* * Add CreateTables func * account registration flow working * tidy * script to step through auth flow * add a lil helper for generating user uris * fiddling with federation a bit * update progress * Tidying and linting
		
			
				
	
	
		
			137 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			137 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| /*
 | |
|    GoToSocial
 | |
|    Copyright (C) 2021 GoToSocial Authors admin@gotosocial.org
 | |
| 
 | |
|    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
 | |
| 
 | |
| import (
 | |
| 	"time"
 | |
| )
 | |
| 
 | |
| // MediaAttachment represents a user-uploaded media attachment: an image/video/audio/gif that is
 | |
| // somewhere in storage and that can be retrieved and served by the router.
 | |
| type MediaAttachment struct {
 | |
| 	// ID of the attachment in the database
 | |
| 	ID string `pg:"type:uuid,default:gen_random_uuid(),pk,notnull,unique"`
 | |
| 	// ID of the status to which this is attached
 | |
| 	StatusID string
 | |
| 	// Where can the attachment be retrieved on a remote server
 | |
| 	RemoteURL string
 | |
| 	// When was the attachment created
 | |
| 	CreatedAt time.Time `pg:"type:timestamp,notnull,default:now()"`
 | |
| 	// When was the attachment last updated
 | |
| 	UpdatedAt time.Time `pg:"type:timestamp,notnull,default:now()"`
 | |
| 	// Type of file (image/gif/audio/video)
 | |
| 	Type FileType `pg:",notnull"`
 | |
| 	// Metadata about the file
 | |
| 	FileMeta FileMeta
 | |
| 	// To which account does this attachment belong
 | |
| 	AccountID string `pg:",notnull"`
 | |
| 	// Description of the attachment (for screenreaders)
 | |
| 	Description string
 | |
| 	// To which scheduled status does this attachment belong
 | |
| 	ScheduledStatusID string
 | |
| 	// What is the generated blurhash of this attachment
 | |
| 	Blurhash string
 | |
| 	// What is the processing status of this attachment
 | |
| 	Processing ProcessingStatus
 | |
| 	// metadata for the whole file
 | |
| 	File File
 | |
| 	// small image thumbnail derived from a larger image, video, or audio file.
 | |
| 	Thumbnail Thumbnail
 | |
| 	// Is this attachment being used as an avatar?
 | |
| 	Avatar bool
 | |
| 	// Is this attachment being used as a header?
 | |
| 	Header bool
 | |
| }
 | |
| 
 | |
| // File refers to the metadata for the whole file
 | |
| type File struct {
 | |
| 	// What is the path of the file in storage.
 | |
| 	Path string
 | |
| 	// What is the MIME content type of the file.
 | |
| 	ContentType string
 | |
| 	// What is the size of the file in bytes.
 | |
| 	FileSize int
 | |
| 	// When was the file last updated.
 | |
| 	UpdatedAt time.Time `pg:"type:timestamp,notnull,default:now()"`
 | |
| }
 | |
| 
 | |
| // Thumbnail refers to a small image thumbnail derived from a larger image, video, or audio file.
 | |
| type Thumbnail struct {
 | |
| 	// What is the path of the file in storage
 | |
| 	Path string
 | |
| 	// What is the MIME content type of the file.
 | |
| 	ContentType string
 | |
| 	// What is the size of the file in bytes
 | |
| 	FileSize int
 | |
| 	// When was the file last updated
 | |
| 	UpdatedAt time.Time `pg:"type:timestamp,notnull,default:now()"`
 | |
| 	// What is the remote URL of the thumbnail
 | |
| 	RemoteURL string
 | |
| }
 | |
| 
 | |
| // ProcessingStatus refers to how far along in the processing stage the attachment is.
 | |
| type ProcessingStatus int
 | |
| 
 | |
| const (
 | |
| 	// ProcessingStatusReceived: the attachment has been received and is awaiting processing. No thumbnail available yet.
 | |
| 	ProcessingStatusReceived ProcessingStatus = 0
 | |
| 	// ProcessingStatusProcessing: the attachment is currently being processed. Thumbnail is available but full media is not.
 | |
| 	ProcessingStatusProcessing ProcessingStatus = 1
 | |
| 	// ProcessingStatusProcessed: the attachment has been fully processed and is ready to be served.
 | |
| 	ProcessingStatusProcessed ProcessingStatus = 2
 | |
| 	// ProcessingStatusError: something went wrong processing the attachment and it won't be tried again--these can be deleted.
 | |
| 	ProcessingStatusError ProcessingStatus = 666
 | |
| )
 | |
| 
 | |
| // FileType refers to the file type of the media attaachment.
 | |
| type FileType string
 | |
| 
 | |
| const (
 | |
| 	// FileTypeImage is for jpegs and pngs
 | |
| 	FileTypeImage FileType = "image"
 | |
| 	// FileTypeGif is for native gifs and soundless videos that have been converted to gifs
 | |
| 	FileTypeGif FileType = "gif"
 | |
| 	// FileTypeAudio is for audio-only files (no video)
 | |
| 	FileTypeAudio FileType = "audio"
 | |
| 	// FileTypeVideo is for files with audio + visual
 | |
| 	FileTypeVideo FileType = "video"
 | |
| )
 | |
| 
 | |
| // FileMeta describes metadata about the actual contents of the file.
 | |
| type FileMeta struct {
 | |
| 	Original Original
 | |
| 	Small    Small
 | |
| }
 | |
| 
 | |
| // Small implements SmallMeta and can be used for a thumbnail of any media type
 | |
| type Small struct {
 | |
| 	Width  int
 | |
| 	Height int
 | |
| 	Size   int
 | |
| 	Aspect float64
 | |
| }
 | |
| 
 | |
| // ImageOriginal implements OriginalMeta for still images
 | |
| type Original struct {
 | |
| 	Width  int
 | |
| 	Height int
 | |
| 	Size   int
 | |
| 	Aspect float64
 | |
| }
 |