| PUT | /tracks/{TrackId} | 
|---|
import 'package:servicestack/servicestack.dart';
import 'dart:typed_data';
// @DataContract
class IdResponse implements IConvertible
{
    // @DataMember(Order=1)
    String? id;
    // @DataMember(Order=2)
    ResponseStatus? responseStatus;
    IdResponse({this.id,this.responseStatus});
    IdResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }
    fromMap(Map<String, dynamic> json) {
        id = json['id'];
        responseStatus = JsonConverters.fromJson(json['responseStatus'],'ResponseStatus',context!);
        return this;
    }
    Map<String, dynamic> toJson() => {
        'id': id,
        'responseStatus': JsonConverters.toJson(responseStatus,'ResponseStatus',context!)
    };
    getTypeName() => "IdResponse";
    TypeContext? context = _ctx;
}
class UpdateTracks implements IPut, IUpdateDb<Tracks>, IConvertible
{
    int? trackId;
    String? name;
    int? albumId;
    int? mediaTypeId;
    int? genreId;
    String? composer;
    int? milliseconds;
    int? bytes;
    double? unitPrice;
    UpdateTracks({this.trackId,this.name,this.albumId,this.mediaTypeId,this.genreId,this.composer,this.milliseconds,this.bytes,this.unitPrice});
    UpdateTracks.fromJson(Map<String, dynamic> json) { fromMap(json); }
    fromMap(Map<String, dynamic> json) {
        trackId = json['trackId'];
        name = json['name'];
        albumId = json['albumId'];
        mediaTypeId = json['mediaTypeId'];
        genreId = json['genreId'];
        composer = json['composer'];
        milliseconds = json['milliseconds'];
        bytes = json['bytes'];
        unitPrice = JsonConverters.toDouble(json['unitPrice']);
        return this;
    }
    Map<String, dynamic> toJson() => {
        'trackId': trackId,
        'name': name,
        'albumId': albumId,
        'mediaTypeId': mediaTypeId,
        'genreId': genreId,
        'composer': composer,
        'milliseconds': milliseconds,
        'bytes': bytes,
        'unitPrice': unitPrice
    };
    getTypeName() => "UpdateTracks";
    TypeContext? context = _ctx;
}
TypeContext _ctx = TypeContext(library: 'blazor_gallery.servicestack.net', types: <String, TypeInfo> {
    'UpdateTracks': TypeInfo(TypeOf.Class, create:() => UpdateTracks()),
});
To override the Content-type in your clients, use the HTTP Accept Header, append the .csv suffix or ?format=csv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
PUT /tracks/{TrackId} HTTP/1.1 
Host: blazor-gallery.servicestack.net 
Accept: text/csv
Content-Type: text/csv
Content-Length: length
{"trackId":0,"name":"String","albumId":0,"mediaTypeId":0,"genreId":0,"composer":"String","milliseconds":0,"bytes":0,"unitPrice":0}
HTTP/1.1 200 OK
Content-Type: text/csv
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"}}}