PUT | /api/products/{id} | Update a Product |
---|
import 'package:servicestack/servicestack.dart';
class UpdateProductResponse implements IConvertible
{
String? message;
HttpStatusCode? status;
ResponseStatus? responseStatus;
UpdateProductResponse({this.message,this.status,this.responseStatus});
UpdateProductResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
message = json['message'];
status = JsonConverters.fromJson(json['status'],'HttpStatusCode',context!);
responseStatus = JsonConverters.fromJson(json['responseStatus'],'ResponseStatus',context!);
return this;
}
Map<String, dynamic> toJson() => {
'message': message,
'status': JsonConverters.toJson(status,'HttpStatusCode',context!),
'responseStatus': JsonConverters.toJson(responseStatus,'ResponseStatus',context!)
};
getTypeName() => "UpdateProductResponse";
TypeContext? context = _ctx;
}
class UpdateProduct implements IConvertible
{
String? id;
String? name;
String? description;
double? price;
String? productType;
int? year;
String? applicationId;
String? requiredProductId;
String? scope;
String? feature;
List<String>? childProductIds;
Map<int,double?>? volumeDiscounts;
UpdateProduct({this.id,this.name,this.description,this.price,this.productType,this.year,this.applicationId,this.requiredProductId,this.scope,this.feature,this.childProductIds,this.volumeDiscounts});
UpdateProduct.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
id = json['id'];
name = json['name'];
description = json['description'];
price = JsonConverters.toDouble(json['price']);
productType = json['productType'];
year = json['year'];
applicationId = json['applicationId'];
requiredProductId = json['requiredProductId'];
scope = json['scope'];
feature = json['feature'];
childProductIds = JsonConverters.fromJson(json['childProductIds'],'List<String>',context!);
volumeDiscounts = JsonConverters.fromJson(json['volumeDiscounts'],'Map<int,double?>',context!);
return this;
}
Map<String, dynamic> toJson() => {
'id': id,
'name': name,
'description': description,
'price': price,
'productType': productType,
'year': year,
'applicationId': applicationId,
'requiredProductId': requiredProductId,
'scope': scope,
'feature': feature,
'childProductIds': JsonConverters.toJson(childProductIds,'List<String>',context!),
'volumeDiscounts': JsonConverters.toJson(volumeDiscounts,'Map<int,double?>',context!)
};
getTypeName() => "UpdateProduct";
TypeContext? context = _ctx;
}
TypeContext _ctx = TypeContext(library: 'accounts.dev.healthmonix.com', types: <String, TypeInfo> {
'UpdateProductResponse': TypeInfo(TypeOf.Class, create:() => UpdateProductResponse()),
'HttpStatusCode': TypeInfo(TypeOf.Class, create:() => HttpStatusCode()),
'UpdateProduct': TypeInfo(TypeOf.Class, create:() => UpdateProduct()),
'Map<int,double?>': TypeInfo(TypeOf.Class, create:() => Map<int,double?>()),
});
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 /api/products/{id} HTTP/1.1
Host: accounts.dev.healthmonix.com
Accept: text/csv
Content-Type: text/csv
Content-Length: length
{"id":"String","name":"String","description":"String","price":0,"productType":"String","year":0,"applicationId":"String","requiredProductId":"String","scope":"String","feature":"String","childProductIds":["String"],"volumeDiscounts":{"0":0}}
HTTP/1.1 200 OK Content-Type: text/csv Content-Length: length {"message":"String","status":"Continue","responseStatus":{"errorCode":"String","message":"String","stackTrace":"String","errors":[{"errorCode":"String","fieldName":"String","message":"String","meta":{"String":"String"}}],"meta":{"String":"String"}}}