export class Likes
{
public artifactIds: number[] = [];
public albumIds: number[] = [];
public constructor(init?: Partial<Likes>) { (Object as any).assign(this, init); }
}
export class AlbumResult
{
public id: number;
public name: string;
public slug: string;
public albumRef: string;
public ownerRef: string;
public primaryArtifactId?: number;
public score: number;
public artifactIds: number[] = [];
public constructor(init?: Partial<AlbumResult>) { (Object as any).assign(this, init); }
}
export class UserResult
{
public refId: string;
public handle?: string;
public avatar?: string;
public profileUrl?: string;
public likes: Likes;
public albums: AlbumResult[] = [];
public constructor(init?: Partial<UserResult>) { (Object as any).assign(this, init); }
}
export class GetUserInfoResponse
{
public result: UserResult;
public responseStatus: ResponseStatus;
public constructor(init?: Partial<GetUserInfoResponse>) { (Object as any).assign(this, init); }
}
export class GetUserInfo implements IGet
{
public refId: string;
public constructor(init?: Partial<GetUserInfo>) { (Object as any).assign(this, init); }
}
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/GetUserInfo HTTP/1.1
Host: blazordiffusion.com
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
refId: String
}
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { result: { refId: String, handle: String, avatar: String, profileUrl: String, likes: { artifactIds: [ 0 ], albumIds: [ 0 ] }, albums: [ { id: 0, name: String, slug: String, albumRef: String, ownerRef: String, primaryArtifactId: 0, score: 0, artifactIds: [ 0 ] } ] }, responseStatus: { errorCode: String, message: String, stackTrace: String, errors: [ { errorCode: String, fieldName: String, message: String, meta: { String: String } } ], meta: { String: String } } }