import 'package:servicestack/servicestack.dart';
// @DataContract
abstract class QueryBase
{
// @DataMember(Order=1)
int? skip;
// @DataMember(Order=2)
int? take;
// @DataMember(Order=3)
String? orderBy;
// @DataMember(Order=4)
String? orderByDesc;
// @DataMember(Order=5)
String? include;
// @DataMember(Order=6)
String? fields;
// @DataMember(Order=7)
Map<String,String?>? meta;
QueryBase({this.skip,this.take,this.orderBy,this.orderByDesc,this.include,this.fields,this.meta});
QueryBase.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
skip = json['skip'];
take = json['take'];
orderBy = json['orderBy'];
orderByDesc = json['orderByDesc'];
include = json['include'];
fields = json['fields'];
meta = JsonConverters.toStringMap(json['meta']);
return this;
}
Map<String, dynamic> toJson() => {
'skip': skip,
'take': take,
'orderBy': orderBy,
'orderByDesc': orderByDesc,
'include': include,
'fields': fields,
'meta': meta
};
getTypeName() => "QueryBase";
TypeContext? context = _ctx;
}
abstract class QueryDb<T> extends QueryBase
{
QueryDb();
QueryDb.fromJson(Map<String, dynamic> json) : super.fromJson(json);
fromMap(Map<String, dynamic> json) {
super.fromMap(json);
return this;
}
Map<String, dynamic> toJson() => super.toJson();
getTypeName() => "QueryDb<$T>";
TypeContext? context = _ctx;
}
enum ComfySampler
{
euler,
euler_cfg_pp,
euler_ancestral,
euler_ancestral_cfg_pp,
huen,
huenpp2,
dpm_2,
dpm_2_ancestral,
lms,
dpm_fast,
dpm_adaptive,
dpmpp_2s_ancestral,
dpmpp_sde,
dpmpp_sde_gpu,
dpmpp_2m,
dpmpp_2m_sde,
dpmpp_2m_sde_gpu,
dpmpp_3m_sde,
dpmpp_3m_sde_gpu,
ddpm,
lcm,
ddim,
uni_pc,
uni_pc_bh2,
}
enum ModelType
{
TextToImage,
TextEncoder,
ImageUpscale,
TextToSpeech,
TextToAudio,
SpeechToText,
ImageToText,
ImageToImage,
ImageWithMask,
VAE,
}
class ProviderModelDefaults implements IConvertible
{
String? id;
Map<String,String?>? apiModels = {};
String? url;
double? quality;
String? aspectRatio;
double? cfgScale;
String? scheduler;
ComfySampler? sampler;
int? width;
int? height;
int? steps;
String? negativePrompt;
ModelType? modelType;
ProviderModelDefaults({this.id,this.apiModels,this.url,this.quality,this.aspectRatio,this.cfgScale,this.scheduler,this.sampler,this.width,this.height,this.steps,this.negativePrompt,this.modelType});
ProviderModelDefaults.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
id = json['id'];
apiModels = JsonConverters.toStringMap(json['apiModels']);
url = json['url'];
quality = JsonConverters.toDouble(json['quality']);
aspectRatio = json['aspectRatio'];
cfgScale = JsonConverters.toDouble(json['cfgScale']);
scheduler = json['scheduler'];
sampler = JsonConverters.fromJson(json['sampler'],'ComfySampler',context!);
width = json['width'];
height = json['height'];
steps = json['steps'];
negativePrompt = json['negativePrompt'];
modelType = JsonConverters.fromJson(json['modelType'],'ModelType',context!);
return this;
}
Map<String, dynamic> toJson() => {
'id': id,
'apiModels': apiModels,
'url': url,
'quality': quality,
'aspectRatio': aspectRatio,
'cfgScale': cfgScale,
'scheduler': scheduler,
'sampler': JsonConverters.toJson(sampler,'ComfySampler',context!),
'width': width,
'height': height,
'steps': steps,
'negativePrompt': negativePrompt,
'modelType': JsonConverters.toJson(modelType,'ModelType',context!)
};
getTypeName() => "ProviderModelDefaults";
TypeContext? context = _ctx;
}
class QueryGenerationModelSettings extends QueryDb<ProviderModelDefaults> implements IConvertible
{
String? id;
QueryGenerationModelSettings({this.id});
QueryGenerationModelSettings.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
super.fromMap(json);
id = json['id'];
return this;
}
Map<String, dynamic> toJson() => super.toJson()..addAll({
'id': id
});
getTypeName() => "QueryGenerationModelSettings";
TypeContext? context = _ctx;
}
// @DataContract
abstract class AuditBase
{
// @DataMember(Order=1)
DateTime? createdDate;
// @DataMember(Order=2)
// @required()
String? createdBy;
// @DataMember(Order=3)
DateTime? modifiedDate;
// @DataMember(Order=4)
// @required()
String? modifiedBy;
// @DataMember(Order=5)
DateTime? deletedDate;
// @DataMember(Order=6)
String? deletedBy;
AuditBase({this.createdDate,this.createdBy,this.modifiedDate,this.modifiedBy,this.deletedDate,this.deletedBy});
AuditBase.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
createdDate = JsonConverters.fromJson(json['createdDate'],'DateTime',context!);
createdBy = json['createdBy'];
modifiedDate = JsonConverters.fromJson(json['modifiedDate'],'DateTime',context!);
modifiedBy = json['modifiedBy'];
deletedDate = JsonConverters.fromJson(json['deletedDate'],'DateTime',context!);
deletedBy = json['deletedBy'];
return this;
}
Map<String, dynamic> toJson() => {
'createdDate': JsonConverters.toJson(createdDate,'DateTime',context!),
'createdBy': createdBy,
'modifiedDate': JsonConverters.toJson(modifiedDate,'DateTime',context!),
'modifiedBy': modifiedBy,
'deletedDate': JsonConverters.toJson(deletedDate,'DateTime',context!),
'deletedBy': deletedBy
};
getTypeName() => "AuditBase";
TypeContext? context = _ctx;
}
class Artifact extends AuditBase implements IConvertible
{
int? id;
// @References(typeof(Creative))
int? creativeId;
String? fileName;
String? filePath;
String? contentType;
int? contentLength;
int? width;
int? height;
int? seed;
String? prompt;
bool? nsfw;
int? averageHash;
int? perceptualHash;
int? differenceHash;
String? background;
String? lqip;
int? quality;
int? likesCount;
int? albumsCount;
int? downloadsCount;
int? searchCount;
int? temporalScore;
int? score;
int? rank;
String? refId;
Map<String,String?>? versions = {};
Artifact({this.id,this.creativeId,this.fileName,this.filePath,this.contentType,this.contentLength,this.width,this.height,this.seed,this.prompt,this.nsfw,this.averageHash,this.perceptualHash,this.differenceHash,this.background,this.lqip,this.quality,this.likesCount,this.albumsCount,this.downloadsCount,this.searchCount,this.temporalScore,this.score,this.rank,this.refId,this.versions});
Artifact.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
super.fromMap(json);
id = json['id'];
creativeId = json['creativeId'];
fileName = json['fileName'];
filePath = json['filePath'];
contentType = json['contentType'];
contentLength = json['contentLength'];
width = json['width'];
height = json['height'];
seed = json['seed'];
prompt = json['prompt'];
nsfw = json['nsfw'];
averageHash = json['averageHash'];
perceptualHash = json['perceptualHash'];
differenceHash = json['differenceHash'];
background = json['background'];
lqip = json['lqip'];
quality = json['quality'];
likesCount = json['likesCount'];
albumsCount = json['albumsCount'];
downloadsCount = json['downloadsCount'];
searchCount = json['searchCount'];
temporalScore = json['temporalScore'];
score = json['score'];
rank = json['rank'];
refId = json['refId'];
versions = JsonConverters.toStringMap(json['versions']);
return this;
}
Map<String, dynamic> toJson() => super.toJson()..addAll({
'id': id,
'creativeId': creativeId,
'fileName': fileName,
'filePath': filePath,
'contentType': contentType,
'contentLength': contentLength,
'width': width,
'height': height,
'seed': seed,
'prompt': prompt,
'nsfw': nsfw,
'averageHash': averageHash,
'perceptualHash': perceptualHash,
'differenceHash': differenceHash,
'background': background,
'lqip': lqip,
'quality': quality,
'likesCount': likesCount,
'albumsCount': albumsCount,
'downloadsCount': downloadsCount,
'searchCount': searchCount,
'temporalScore': temporalScore,
'score': score,
'rank': rank,
'refId': refId,
'versions': versions
});
getTypeName() => "Artifact";
TypeContext? context = _ctx;
}
class ArtifactResult extends Artifact implements IConvertible
{
String? userPrompt;
List<String>? artistNames = [];
List<String>? modifierNames = [];
int? primaryArtifactId;
String? ownerRef;
double? similarity;
ArtifactResult({this.userPrompt,this.artistNames,this.modifierNames,this.primaryArtifactId,this.ownerRef,this.similarity});
ArtifactResult.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
super.fromMap(json);
userPrompt = json['userPrompt'];
artistNames = JsonConverters.fromJson(json['artistNames'],'List<String>',context!);
modifierNames = JsonConverters.fromJson(json['modifierNames'],'List<String>',context!);
primaryArtifactId = json['primaryArtifactId'];
ownerRef = json['ownerRef'];
similarity = JsonConverters.toDouble(json['similarity']);
return this;
}
Map<String, dynamic> toJson() => super.toJson()..addAll({
'userPrompt': userPrompt,
'artistNames': JsonConverters.toJson(artistNames,'List<String>',context!),
'modifierNames': JsonConverters.toJson(modifierNames,'List<String>',context!),
'primaryArtifactId': primaryArtifactId,
'ownerRef': ownerRef,
'similarity': similarity
});
getTypeName() => "ArtifactResult";
TypeContext? context = _ctx;
}
// @DataContract
class QueryResponse<T> implements IConvertible
{
// @DataMember(Order=1)
int? offset;
// @DataMember(Order=2)
int? total;
// @DataMember(Order=3)
List<ArtifactResult>? results;
// @DataMember(Order=4)
Map<String,String?>? meta;
// @DataMember(Order=5)
ResponseStatus? responseStatus;
QueryResponse({this.offset,this.total,this.results,this.meta,this.responseStatus});
QueryResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
offset = json['offset'];
total = json['total'];
results = JsonConverters.fromJson(json['results'],'List<ArtifactResult>',context!);
meta = JsonConverters.toStringMap(json['meta']);
responseStatus = JsonConverters.fromJson(json['responseStatus'],'ResponseStatus',context!);
return this;
}
Map<String, dynamic> toJson() => {
'offset': offset,
'total': total,
'results': JsonConverters.toJson(results,'List<ArtifactResult>',context!),
'meta': meta,
'responseStatus': JsonConverters.toJson(responseStatus,'ResponseStatus',context!)
};
getTypeName() => "QueryResponse<$T>";
TypeContext? context = _ctx;
}
TypeContext _ctx = TypeContext(library: 'blazordiffusion.com', types: <String, TypeInfo> {
'ComfySampler': TypeInfo(TypeOf.Enum, enumValues:ComfySampler.values),
'ModelType': TypeInfo(TypeOf.Enum, enumValues:ModelType.values),
'ProviderModelDefaults': TypeInfo(TypeOf.Class, create:() => ProviderModelDefaults()),
'QueryGenerationModelSettings': TypeInfo(TypeOf.Class, create:() => QueryGenerationModelSettings()),
'List<ProviderModelDefaults>': TypeInfo(TypeOf.Class, create:() => <ProviderModelDefaults>[]),
'Artifact': TypeInfo(TypeOf.Class, create:() => Artifact()),
'ArtifactResult': TypeInfo(TypeOf.Class, create:() => ArtifactResult()),
'List<ArtifactResult>': TypeInfo(TypeOf.Class, create:() => <ArtifactResult>[]),
});
Dart QueryGenerationModelSettings DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .json suffix or ?format=json
To embed the response in a jsonp callback, append ?callback=myCallback
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /json/reply/QueryGenerationModelSettings HTTP/1.1
Host: blazordiffusion.com
Accept: application/json
Content-Type: application/json
Content-Length: length
{"id":"String","skip":0,"take":0,"orderBy":"String","orderByDesc":"String","include":"String","fields":"String","meta":{"String":"String"}}
HTTP/1.1 200 OK Content-Type: application/json Content-Length: length {"offset":0,"total":0,"results":[{"id":"String","apiModels":{"String":"String"},"url":"String","quality":0,"aspectRatio":"String","cfgScale":0,"scheduler":"String","sampler":"euler","width":0,"height":0,"steps":0,"negativePrompt":"String","modelType":"TextToImage"}],"meta":{"String":"String"},"responseStatus":{"errorCode":"String","message":"String","stackTrace":"String","errors":[{"errorCode":"String","fieldName":"String","message":"String","meta":{"String":"String"}}],"meta":{"String":"String"}}}