Performer checksum from name. Default image

This commit is contained in:
WithoutPants
2019-08-21 12:51:30 +10:00
parent 32a4f34c7c
commit 996fd9c70a
8 changed files with 30 additions and 14 deletions

View File

@@ -15,7 +15,7 @@ mutation PerformerCreate(
$twitter: String, $twitter: String,
$instagram: String, $instagram: String,
$favorite: Boolean, $favorite: Boolean,
$image: String!) { $image: String) {
performerCreate(input: { performerCreate(input: {
name: $name, name: $name,

View File

@@ -41,7 +41,7 @@ input PerformerCreateInput {
instagram: String instagram: String
favorite: Boolean favorite: Boolean
"""This should be base64 encoded""" """This should be base64 encoded"""
image: String! image: String
} }
input PerformerUpdateInput { input PerformerUpdateInput {

View File

@@ -3,16 +3,26 @@ package api
import ( import (
"context" "context"
"database/sql" "database/sql"
"strconv"
"time"
"github.com/stashapp/stash/pkg/database" "github.com/stashapp/stash/pkg/database"
"github.com/stashapp/stash/pkg/models" "github.com/stashapp/stash/pkg/models"
"github.com/stashapp/stash/pkg/utils" "github.com/stashapp/stash/pkg/utils"
"strconv"
"time"
) )
func (r *mutationResolver) PerformerCreate(ctx context.Context, input models.PerformerCreateInput) (*models.Performer, error) { func (r *mutationResolver) PerformerCreate(ctx context.Context, input models.PerformerCreateInput) (*models.Performer, error) {
// Process the base 64 encoded image string // generate checksum from performer name rather than image
checksum, imageData, err := utils.ProcessBase64Image(input.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 { if err != nil {
return nil, err return nil, err
} }
@@ -188,4 +198,3 @@ func (r *mutationResolver) PerformerDestroy(ctx context.Context, input models.Pe
} }
return true, nil return true, nil
} }

View File

@@ -2059,7 +2059,7 @@ input PerformerCreateInput {
instagram: String instagram: String
favorite: Boolean favorite: Boolean
"""This should be base64 encoded""" """This should be base64 encoded"""
image: String! image: String
} }
input PerformerUpdateInput { input PerformerUpdateInput {
@@ -8255,7 +8255,7 @@ func (ec *executionContext) unmarshalInputPerformerCreateInput(ctx context.Conte
} }
case "image": case "image":
var err error var err error
it.Image, err = ec.unmarshalNString2string(ctx, v) it.Image, err = ec.unmarshalOString2string(ctx, v)
if err != nil { if err != nil {
return it, err return it, err
} }

View File

@@ -106,7 +106,7 @@ type PerformerCreateInput struct {
Instagram *string `json:"instagram"` Instagram *string `json:"instagram"`
Favorite *bool `json:"favorite"` Favorite *bool `json:"favorite"`
// This should be base64 encoded // This should be base64 encoded
Image string `json:"image"` Image *string `json:"image"`
} }
type PerformerDestroyInput struct { type PerformerDestroyInput struct {

View File

@@ -27,3 +27,5 @@ type Performer struct {
CreatedAt SQLiteTimestamp `db:"created_at" json:"created_at"` CreatedAt SQLiteTimestamp `db:"created_at" json:"created_at"`
UpdatedAt SQLiteTimestamp `db:"updated_at" json:"updated_at"` UpdatedAt SQLiteTimestamp `db:"updated_at" json:"updated_at"`
} }
var DefaultPerformerImage string = ""

View File

@@ -12,6 +12,11 @@ func MD5FromBytes(data []byte) string {
return fmt.Sprintf("%x", result) return fmt.Sprintf("%x", result)
} }
func MD5FromString(str string) string {
data := []byte(str)
return MD5FromBytes(data)
}
func MD5FromFilePath(filePath string) (string, error) { func MD5FromFilePath(filePath string) (string, error) {
f, err := os.Open(filePath) f, err := os.Open(filePath)
if err != nil { if err != nil {

View File

@@ -1,6 +1,6 @@
/* tslint:disable */ /* tslint:disable */
/* eslint-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> = T | undefined; export type Maybe<T> = T | undefined;
export interface SceneFilterType { export interface SceneFilterType {
@@ -147,7 +147,7 @@ export interface PerformerCreateInput {
favorite?: Maybe<boolean>; favorite?: Maybe<boolean>;
/** This should be base64 encoded */ /** This should be base64 encoded */
image: string; image?: Maybe<string>;
} }
export interface PerformerUpdateInput { export interface PerformerUpdateInput {
@@ -294,7 +294,7 @@ export type PerformerCreateVariables = {
twitter?: Maybe<string>; twitter?: Maybe<string>;
instagram?: Maybe<string>; instagram?: Maybe<string>;
favorite?: Maybe<boolean>; favorite?: Maybe<boolean>;
image: string; image?: Maybe<string>;
}; };
export type PerformerCreateMutation = { export type PerformerCreateMutation = {
@@ -1572,7 +1572,7 @@ export const PerformerCreateDocument = gql`
$twitter: String $twitter: String
$instagram: String $instagram: String
$favorite: Boolean $favorite: Boolean
$image: String! $image: String
) { ) {
performerCreate( performerCreate(
input: { input: {