Blazor Diffusion

<back to all web services

GetCreative

Creatives
import datetime
import decimal
from marshmallow.fields import *
from servicestack import *
from typing import *
from dataclasses import dataclass, field
from dataclasses_json import dataclass_json, LetterCase, Undefined, config
from enum import Enum, IntEnum


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class AuditBase:
    created_date: datetime.datetime = datetime.datetime(1, 1, 1)
    # @Required()
    created_by: Optional[str] = None

    modified_date: datetime.datetime = datetime.datetime(1, 1, 1)
    # @Required()
    modified_by: Optional[str] = None

    deleted_date: Optional[datetime.datetime] = None
    deleted_by: Optional[str] = None


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Artist(AuditBase):
    id: int = 0
    first_name: Optional[str] = None
    last_name: Optional[str] = None
    year_died: Optional[int] = None
    type: Optional[List[str]] = None
    score: int = 0
    rank: int = 0


# @ValidateRequest(Validator="HasRole(`Moderator`)")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class CreativeArtist:
    id: int = 0
    # @References(typeof(Creative))
    creative_id: int = 0

    # @References(typeof(Artist))
    artist_id: int = 0

    artist: Optional[Artist] = None


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Modifier(AuditBase):
    id: int = 0
    name: Optional[str] = None
    category: Optional[str] = None
    description: Optional[str] = None
    score: int = 0
    rank: int = 0


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class CreativeModifier:
    id: int = 0
    # @References(typeof(Creative))
    creative_id: int = 0

    # @References(typeof(Modifier))
    modifier_id: int = 0

    modifier: Optional[Modifier] = None


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Artifact(AuditBase):
    id: int = 0
    # @References(typeof(Creative))
    creative_id: int = 0

    file_name: Optional[str] = None
    file_path: Optional[str] = None
    content_type: Optional[str] = None
    content_length: int = 0
    width: int = 0
    height: int = 0
    seed: int = 0
    prompt: Optional[str] = None
    nsfw: Optional[bool] = None
    average_hash: Optional[int] = None
    perceptual_hash: Optional[int] = None
    difference_hash: Optional[int] = None
    background: Optional[str] = None
    lqip: Optional[str] = None
    quality: int = 0
    likes_count: int = 0
    albums_count: int = 0
    downloads_count: int = 0
    search_count: int = 0
    temporal_score: int = 0
    score: int = 0
    rank: int = 0
    ref_id: Optional[str] = None
    versions: Dict[str, str] = field(default_factory=dict)


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class Creative(AuditBase):
    id: int = 0
    user_prompt: Optional[str] = None
    prompt: Optional[str] = None
    images: int = 0
    width: int = 0
    height: int = 0
    steps: int = 0
    curated_artifact_id: Optional[int] = None
    primary_artifact_id: Optional[int] = None
    artist_names: List[str] = field(default_factory=list)
    modifier_names: List[str] = field(default_factory=list)
    artists: List[CreativeArtist] = field(default_factory=list)
    modifiers: List[CreativeModifier] = field(default_factory=list)
    artifacts: List[Artifact] = field(default_factory=list)
    error: Optional[str] = None
    owner_id: Optional[int] = None
    owner_ref: Optional[str] = None
    key: Optional[str] = None
    curated: bool = False
    rating: Optional[int] = None
    private: bool = False
    score: int = 0
    rank: int = 0
    ref_id: Optional[str] = None
    request_id: Optional[str] = None
    engine_id: Optional[str] = None


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class GetCreativeResponse:
    result: Optional[Creative] = None
    response_status: Optional[ResponseStatus] = None


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class GetCreative(IGet):
    id: Optional[int] = None
    artifact_id: Optional[int] = None

Python GetCreative DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv

HTTP + JSV

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

POST /jsv/reply/GetCreative HTTP/1.1 
Host: blazordiffusion.com 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	id: 0,
	artifactId: 0
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	result: 
	{
		id: 0,
		userPrompt: String,
		prompt: String,
		images: 0,
		width: 0,
		height: 0,
		steps: 0,
		curatedArtifactId: 0,
		primaryArtifactId: 0,
		artistNames: 
		[
			String
		],
		modifierNames: 
		[
			String
		],
		artists: 
		[
			{
				id: 0,
				creativeId: 0,
				artistId: 0,
				artist: 
				{
					id: 0,
					firstName: String,
					lastName: String,
					yearDied: 0,
					type: 
					[
						String
					],
					score: 0,
					rank: 0,
					createdDate: 0001-01-01,
					createdBy: String,
					modifiedDate: 0001-01-01,
					modifiedBy: String,
					deletedDate: 0001-01-01,
					deletedBy: String
				}
			}
		],
		modifiers: 
		[
			{
				id: 0,
				creativeId: 0,
				modifierId: 0,
				modifier: 
				{
					id: 0,
					name: String,
					category: String,
					description: String,
					score: 0,
					rank: 0,
					createdDate: 0001-01-01,
					createdBy: String,
					modifiedDate: 0001-01-01,
					modifiedBy: String,
					deletedDate: 0001-01-01,
					deletedBy: String
				}
			}
		],
		artifacts: 
		[
			{
				id: 0,
				creativeId: 0,
				fileName: String,
				filePath: String,
				contentType: String,
				contentLength: 0,
				width: 0,
				height: 0,
				seed: 0,
				prompt: String,
				nsfw: False,
				averageHash: 0,
				perceptualHash: 0,
				differenceHash: 0,
				background: String,
				lqip: String,
				quality: 0,
				likesCount: 0,
				albumsCount: 0,
				downloadsCount: 0,
				searchCount: 0,
				temporalScore: 0,
				score: 0,
				rank: 0,
				refId: String,
				versions: 
				{
					String: String
				},
				createdDate: 0001-01-01,
				createdBy: String,
				modifiedDate: 0001-01-01,
				modifiedBy: String,
				deletedDate: 0001-01-01,
				deletedBy: String
			}
		],
		error: String,
		ownerId: 0,
		ownerRef: String,
		key: String,
		curated: False,
		rating: 0,
		private: False,
		score: 0,
		rank: 0,
		refId: String,
		requestId: String,
		engineId: String,
		createdDate: 0001-01-01,
		createdBy: String,
		modifiedDate: 0001-01-01,
		modifiedBy: String,
		deletedDate: 0001-01-01,
		deletedBy: String
	},
	responseStatus: 
	{
		errorCode: String,
		message: String,
		stackTrace: String,
		errors: 
		[
			{
				errorCode: String,
				fieldName: String,
				message: String,
				meta: 
				{
					String: String
				}
			}
		],
		meta: 
		{
			String: String
		}
	}
}