2021-02-28 14:17:18 +00:00
/ *
2021-03-01 14:41:43 +00:00
GoToSocial
Copyright ( C ) 2021 GoToSocial Authors admin @ gotosocial . org
2021-02-28 14:17:18 +00:00
2021-03-01 14:41:43 +00:00
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 .
2021-02-28 14:17:18 +00:00
2021-03-01 14:41:43 +00:00
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 .
2021-02-28 14:17:18 +00:00
2021-03-01 14:41:43 +00:00
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-02-28 14:17:18 +00:00
* /
2021-04-19 17:42:19 +00:00
package gtsmodel
2021-04-01 18:46:45 +00:00
import "time"
2021-04-19 17:42:19 +00:00
// StatusFave refers to a 'fave' or 'like' in the database, from one account, targeting the status of another account
type StatusFave struct {
// id of this fave in the database
2021-04-01 18:46:45 +00:00
ID string ` pg:"type:uuid,default:gen_random_uuid(),pk,notnull,unique" `
2021-04-19 17:42:19 +00:00
// when was this fave created
2021-04-01 18:46:45 +00:00
CreatedAt time . Time ` pg:"type:timestamp,notnull,default:now()" `
2021-04-19 17:42:19 +00:00
// id of the account that created ('did') the fave
AccountID string ` pg:",notnull" `
// id the account owning the faved status
TargetAccountID string ` pg:",notnull" `
// database id of the status that has been 'faved'
StatusID string ` pg:",notnull" `
2021-05-24 16:49:48 +00:00
// ActivityPub URI of this fave
URI string ` pg:",notnull" `
2021-04-19 17:42:19 +00:00
2021-05-24 16:49:48 +00:00
// GTSStatus is the status being interacted with. It won't be put or retrieved from the db, it's just for conveniently passing a pointer around.
GTSStatus * Status ` pg:"-" `
// GTSTargetAccount is the account being interacted with. It won't be put or retrieved from the db, it's just for conveniently passing a pointer around.
GTSTargetAccount * Account ` pg:"-" `
// GTSFavingAccount is the account doing the faving. It won't be put or retrieved from the db, it's just for conveniently passing a pointer around.
GTSFavingAccount * Account ` pg:"-" `
2021-03-22 21:26:54 +00:00
}