mirror of
https://github.com/stashapp/stash.git
synced 2025-12-17 12:24:38 +03:00
Performer checksum from name. Default image
This commit is contained in:
@@ -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,
|
||||||
|
|||||||
@@ -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 {
|
||||||
|
|||||||
@@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -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.unmarshalOString2ᚖstring(ctx, v)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return it, err
|
return it, err
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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 {
|
||||||
|
|||||||
@@ -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 = ""
|
||||||
|
|||||||
@@ -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 {
|
||||||
|
|||||||
@@ -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: {
|
||||||
|
|||||||
Reference in New Issue
Block a user