// @DataContract
export class IdResponse
{
// @DataMember(Order=1)
public id: string;
// @DataMember(Order=2)
public responseStatus: ResponseStatus;
public constructor(init?: Partial<IdResponse>) { (Object as any).assign(this, init); }
}
export enum TaskType
{
OpenAiChat = 1,
Comfy = 2,
}
export class ApiProviderModel
{
public model: string;
public apiModel: string;
public constructor(init?: Partial<ApiProviderModel>) { (Object as any).assign(this, init); }
}
export class CreateApiProvider implements ICreateDb<ApiProvider>
{
// @Validate(Validator="GreaterThan(0)")
public apiTypeId: number;
public apiBaseUrl: string;
// @Validate(Validator="NotEmpty")
public name: string;
public apiKeyVar: string;
public apiKey: string;
public apiKeyHeader: string;
public heartbeatUrl: string;
public taskPaths: { [index:string]: string; };
public concurrency: number;
public priority: number;
public enabled: boolean;
public models: ApiProviderModel[];
public selectedModels: string[];
public constructor(init?: Partial<CreateApiProvider>) { (Object as any).assign(this, init); }
}
TypeScript CreateApiProvider DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /jsv/reply/CreateApiProvider HTTP/1.1
Host: blazordiffusion.com
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
apiTypeId: 0,
apiBaseUrl: String,
name: String,
apiKeyVar: String,
apiKey: String,
apiKeyHeader: String,
heartbeatUrl: String,
taskPaths:
{
OpenAiChat: String
},
concurrency: 0,
priority: 0,
enabled: False,
models:
[
{
model: String,
apiModel: String
}
],
selectedModels:
[
String
]
}
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { id: String, responseStatus: { errorCode: String, message: String, stackTrace: String, errors: [ { errorCode: String, fieldName: String, message: String, meta: { String: String } } ], meta: { String: String } } }