Hmx Accounts

<back to all web services

UpdateProduct

Requires Authentication
The following routes are available for this service:
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?>()),
});

Dart UpdateProduct 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

HTTP + JSON

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: application/json
Content-Type: application/json
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: application/json
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"}}}