From 251611c5a086c698a0f6980afe5ec51fe8dcd295 Mon Sep 17 00:00:00 2001 From: SoXX Date: Mon, 15 Jul 2024 15:10:44 +0200 Subject: [PATCH] feat: added json notation Signed-off-by: SoXX --- pkg/models/orm.go | 11 ++++++----- pkg/models/post.go | 8 ++++---- pkg/models/postReference.go | 14 +++++++------- pkg/models/source.go | 10 +++++----- pkg/models/tag.go | 18 +++++++++--------- pkg/models/user.go | 4 ++-- pkg/models/userFavorite.go | 6 +++--- pkg/models/userSource.go | 20 ++++++++++---------- 8 files changed, 46 insertions(+), 45 deletions(-) diff --git a/pkg/models/orm.go b/pkg/models/orm.go index 7235e57..f9209d9 100644 --- a/pkg/models/orm.go +++ b/pkg/models/orm.go @@ -1,9 +1,10 @@ package models import ( + "time" + gonanoid "github.com/matoous/go-nanoid/v2" "gorm.io/gorm" - "time" ) type ID interface { @@ -11,10 +12,10 @@ type ID interface { } type BaseModel[T ID] struct { - ID T `gorm:"primaryKey"` - CreatedAt time.Time - UpdatedAt time.Time - DeletedAt gorm.DeletedAt `gorm:"index"` + ID T `json:"id" gorm:"primaryKey"` + CreatedAt time.Time `json:"-"` + UpdatedAt time.Time `json:"-"` + DeletedAt gorm.DeletedAt `json:"-" gorm:"index"` } func (base *BaseModel[T]) BeforeCreate(db *gorm.DB) error { diff --git a/pkg/models/post.go b/pkg/models/post.go index bfe9946..7d3f450 100644 --- a/pkg/models/post.go +++ b/pkg/models/post.go @@ -3,10 +3,10 @@ package models // Post model type Post struct { BaseModel[AnthrovePostID] - Rating Rating `gorm:"type:enum('safe','questionable','explicit')"` - Tags []Tag `gorm:"many2many:post_tags;"` - Favorites []UserFavorites `gorm:"foreignKey:PostID"` - References []PostReference `gorm:"foreignKey:PostID"` + Rating Rating `json:"rating" gorm:"type:enum('safe','questionable','explicit')"` + Tags []Tag `json:"tags" gorm:"many2many:post_tags;"` + Favorites []UserFavorites `json:"-" gorm:"foreignKey:PostID"` + References []PostReference `json:"-" gorm:"foreignKey:PostID"` } func (Post) TableName() string { diff --git a/pkg/models/postReference.go b/pkg/models/postReference.go index efaed73..615244a 100644 --- a/pkg/models/postReference.go +++ b/pkg/models/postReference.go @@ -1,17 +1,17 @@ package models type PostReference struct { - PostID string `gorm:"primaryKey"` - SourceID string `gorm:"primaryKey"` - URL string `gorm:"primaryKey"` + PostID string `json:"post_id" gorm:"primaryKey"` + SourceID string `json:"source_id" gorm:"primaryKey"` + URL string `json:"url" gorm:"primaryKey"` PostReferenceConfig } type PostReferenceConfig struct { - SourcePostID string - FullFileURL string - PreviewFileURL string - SampleFileURL string + SourcePostID string `json:"source_post_id"` + FullFileURL string `json:"full_file_url"` + PreviewFileURL string `json:"preview_file_url"` + SampleFileURL string `json:"sample_file_url"` } func (PostReference) TableName() string { diff --git a/pkg/models/source.go b/pkg/models/source.go index 200b48e..9027b55 100644 --- a/pkg/models/source.go +++ b/pkg/models/source.go @@ -3,11 +3,11 @@ package models // Source model type Source struct { BaseModel[AnthroveSourceID] - DisplayName string - Domain string `gorm:"not null;unique"` - Icon string `gorm:"not null"` - UserSources []UserSource `gorm:"foreignKey:SourceID"` - References []PostReference `gorm:"foreignKey:SourceID"` + DisplayName string `json:"display_name" ` + Domain string `json:"domain" gorm:"not null;unique"` + Icon string `json:"icon" gorm:"not null"` + UserSources []UserSource `json:"-" gorm:"foreignKey:SourceID"` + References []PostReference `json:"references" gorm:"foreignKey:SourceID"` } func (Source) TableName() string { diff --git a/pkg/models/tag.go b/pkg/models/tag.go index 583cd78..09fafb9 100644 --- a/pkg/models/tag.go +++ b/pkg/models/tag.go @@ -2,11 +2,11 @@ package models // Tag models type Tag struct { - Name string `gorm:"primaryKey"` - Type TagType `gorm:"column:tag_type"` - Aliases []TagAlias `gorm:"foreignKey:TagID"` - Groups []TagGroup `gorm:"foreignKey:TagID"` - Posts []Post `gorm:"many2many:post_tags;"` + Name string `json:"name" gorm:"primaryKey"` + Type TagType `json:"type" gorm:"column:tag_type"` + Aliases []TagAlias `json:"aliases" gorm:"foreignKey:TagID"` + Groups []TagGroup `json:"groups" gorm:"foreignKey:TagID"` + Posts []Post `json:"posts" gorm:"many2many:post_tags;"` } func (Tag) TableName() string { @@ -15,8 +15,8 @@ func (Tag) TableName() string { // TagAlias model type TagAlias struct { - Name string `gorm:"primaryKey"` - TagID string + Name string `json:"name" gorm:"primaryKey"` + TagID string `json:"tag_id"` } func (TagAlias) TableName() string { @@ -25,8 +25,8 @@ func (TagAlias) TableName() string { // TagGroup model type TagGroup struct { - Name string `gorm:"primaryKey"` - TagID string + Name string `json:"name" gorm:"primaryKey"` + TagID string `json:"tag_id"` } func (TagGroup) TableName() string { diff --git a/pkg/models/user.go b/pkg/models/user.go index 95ba75d..bc2d575 100644 --- a/pkg/models/user.go +++ b/pkg/models/user.go @@ -3,8 +3,8 @@ package models // User model type User struct { BaseModel[AnthroveUserID] - Favorites []UserFavorites `gorm:"foreignKey:UserID"` - Sources []UserSource `gorm:"foreignKey:UserID"` + Favorites []UserFavorites `json:"-" gorm:"foreignKey:UserID"` + Sources []UserSource `json:"-" gorm:"foreignKey:UserID"` } func (User) TableName() string { diff --git a/pkg/models/userFavorite.go b/pkg/models/userFavorite.go index 028b907..182af8f 100644 --- a/pkg/models/userFavorite.go +++ b/pkg/models/userFavorite.go @@ -3,9 +3,9 @@ package models import "time" type UserFavorites struct { - UserID string `gorm:"primaryKey"` - PostID string `gorm:"primaryKey"` - CreatedAt time.Time + UserID string `json:"user_id" gorm:"primaryKey"` + PostID string `json:"post_id" gorm:"primaryKey"` + CreatedAt time.Time `json:"-"` } func (UserFavorites) TableName() string { diff --git a/pkg/models/userSource.go b/pkg/models/userSource.go index 8ac124e..9ee0f87 100644 --- a/pkg/models/userSource.go +++ b/pkg/models/userSource.go @@ -3,16 +3,16 @@ package models import "time" type UserSource struct { - User User `gorm:"foreignKey:ID;references:UserID"` - UserID string `gorm:"primaryKey"` - Source Source `gorm:"foreignKey:ID;references:SourceID"` - SourceID string `gorm:"primaryKey"` - ScrapeTimeInterval string - AccountUsername string - AccountID string - LastScrapeTime time.Time - AccountValidate bool - AccountValidationKey string + User User `json:"user" gorm:"foreignKey:ID;references:UserID"` + UserID string `json:"user_id" gorm:"primaryKey"` + Source Source `json:"source" gorm:"foreignKey:ID;references:SourceID"` + SourceID string `json:"source_id" gorm:"primaryKey"` + ScrapeTimeInterval string `json:"scrape_time_interval"` + AccountUsername string `json:"account_username"` + AccountID string `json:"account_id"` + LastScrapeTime time.Time `json:"last_scrape_time"` + AccountValidate bool `json:"account_validate"` + AccountValidationKey string `json:"-"` } func (UserSource) TableName() string {