diff --git a/graphql/documents/mutations/performer.graphql b/graphql/documents/mutations/performer.graphql index a74a3a5f7..ec785f5f2 100644 --- a/graphql/documents/mutations/performer.graphql +++ b/graphql/documents/mutations/performer.graphql @@ -15,7 +15,7 @@ mutation PerformerCreate( $twitter: String, $instagram: String, $favorite: Boolean, - $image: String!) { + $image: String) { performerCreate(input: { name: $name, diff --git a/graphql/schema/types/performer.graphql b/graphql/schema/types/performer.graphql index af52b704c..a1ba8e6f7 100644 --- a/graphql/schema/types/performer.graphql +++ b/graphql/schema/types/performer.graphql @@ -41,7 +41,7 @@ input PerformerCreateInput { instagram: String favorite: Boolean """This should be base64 encoded""" - image: String! + image: String } input PerformerUpdateInput { diff --git a/pkg/api/resolver_mutation_performer.go b/pkg/api/resolver_mutation_performer.go index 54a7693e4..854e012f9 100644 --- a/pkg/api/resolver_mutation_performer.go +++ b/pkg/api/resolver_mutation_performer.go @@ -3,16 +3,26 @@ package api import ( "context" "database/sql" + "strconv" + "time" + "github.com/stashapp/stash/pkg/database" "github.com/stashapp/stash/pkg/models" "github.com/stashapp/stash/pkg/utils" - "strconv" - "time" ) func (r *mutationResolver) PerformerCreate(ctx context.Context, input models.PerformerCreateInput) (*models.Performer, error) { - // Process the base 64 encoded image string - checksum, imageData, err := utils.ProcessBase64Image(input.Image) + // generate checksum from performer name rather than image + checksum := utils.MD5FromString(*input.Name) + + var imageData []byte + var err error + + if input.Image == nil { + input.Image = &models.DefaultPerformerImage + } + + _, imageData, err = utils.ProcessBase64Image(*input.Image) if err != nil { return nil, err } @@ -188,4 +198,3 @@ func (r *mutationResolver) PerformerDestroy(ctx context.Context, input models.Pe } return true, nil } - diff --git a/pkg/models/generated_exec.go b/pkg/models/generated_exec.go index 48627edc4..19254cb2c 100644 --- a/pkg/models/generated_exec.go +++ b/pkg/models/generated_exec.go @@ -2059,7 +2059,7 @@ input PerformerCreateInput { instagram: String favorite: Boolean """This should be base64 encoded""" - image: String! + image: String } input PerformerUpdateInput { @@ -8255,7 +8255,7 @@ func (ec *executionContext) unmarshalInputPerformerCreateInput(ctx context.Conte } case "image": var err error - it.Image, err = ec.unmarshalNString2string(ctx, v) + it.Image, err = ec.unmarshalOString2áš–string(ctx, v) if err != nil { return it, err } diff --git a/pkg/models/generated_models.go b/pkg/models/generated_models.go index 351270d16..311a8a843 100644 --- a/pkg/models/generated_models.go +++ b/pkg/models/generated_models.go @@ -106,7 +106,7 @@ type PerformerCreateInput struct { Instagram *string `json:"instagram"` Favorite *bool `json:"favorite"` // This should be base64 encoded - Image string `json:"image"` + Image *string `json:"image"` } type PerformerDestroyInput struct { diff --git a/pkg/models/model_performer.go b/pkg/models/model_performer.go index 8d3beb3db..95c3e4516 100644 --- a/pkg/models/model_performer.go +++ b/pkg/models/model_performer.go @@ -27,3 +27,5 @@ type Performer struct { CreatedAt SQLiteTimestamp `db:"created_at" json:"created_at"` UpdatedAt SQLiteTimestamp `db:"updated_at" json:"updated_at"` } + +var DefaultPerformerImage string = "" diff --git a/pkg/utils/crypto.go b/pkg/utils/crypto.go index efa124a34..4fd911ccb 100644 --- a/pkg/utils/crypto.go +++ b/pkg/utils/crypto.go @@ -12,6 +12,11 @@ func MD5FromBytes(data []byte) string { return fmt.Sprintf("%x", result) } +func MD5FromString(str string) string { + data := []byte(str) + return MD5FromBytes(data) +} + func MD5FromFilePath(filePath string) (string, error) { f, err := os.Open(filePath) if err != nil { diff --git a/ui/v2/src/core/generated-graphql.tsx b/ui/v2/src/core/generated-graphql.tsx index d0239e0b2..57ee5ba2d 100644 --- a/ui/v2/src/core/generated-graphql.tsx +++ b/ui/v2/src/core/generated-graphql.tsx @@ -1,6 +1,6 @@ /* tslint:disable */ /* eslint-disable */ -// Generated in 2019-08-14T07:29:27+10:00 +// Generated in 2019-08-20T18:32:35+10:00 export type Maybe = T | undefined; export interface SceneFilterType { @@ -147,7 +147,7 @@ export interface PerformerCreateInput { favorite?: Maybe; /** This should be base64 encoded */ - image: string; + image?: Maybe; } export interface PerformerUpdateInput { @@ -294,7 +294,7 @@ export type PerformerCreateVariables = { twitter?: Maybe; instagram?: Maybe; favorite?: Maybe; - image: string; + image?: Maybe; }; export type PerformerCreateMutation = { @@ -1572,7 +1572,7 @@ export const PerformerCreateDocument = gql` $twitter: String $instagram: String $favorite: Boolean - $image: String! + $image: String ) { performerCreate( input: {