Hmx Accounts

<back to all web services

GetProduct

Requires Authentication
The following routes are available for this service:
GET/api/products/{id}Get Product by Key
import 'package:servicestack/servicestack.dart';

class ProductDto implements IConvertible
{
    String? id;
    String? name;
    String? description;
    String? longDescription;
    String? details;
    double? price;
    String? productType;
    int? year;
    String? applicationId;
    String? requiredProductId;
    String? scope;
    String? feature;
    bool? isVisible;
    String? iconUrl;
    Map<int,double?>? volumeDiscounts;

    ProductDto({this.id,this.name,this.description,this.longDescription,this.details,this.price,this.productType,this.year,this.applicationId,this.requiredProductId,this.scope,this.feature,this.isVisible,this.iconUrl,this.volumeDiscounts});
    ProductDto.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        id = json['id'];
        name = json['name'];
        description = json['description'];
        longDescription = json['longDescription'];
        details = json['details'];
        price = JsonConverters.toDouble(json['price']);
        productType = json['productType'];
        year = json['year'];
        applicationId = json['applicationId'];
        requiredProductId = json['requiredProductId'];
        scope = json['scope'];
        feature = json['feature'];
        isVisible = json['isVisible'];
        iconUrl = json['iconUrl'];
        volumeDiscounts = JsonConverters.fromJson(json['volumeDiscounts'],'Map<int,double?>',context!);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'id': id,
        'name': name,
        'description': description,
        'longDescription': longDescription,
        'details': details,
        'price': price,
        'productType': productType,
        'year': year,
        'applicationId': applicationId,
        'requiredProductId': requiredProductId,
        'scope': scope,
        'feature': feature,
        'isVisible': isVisible,
        'iconUrl': iconUrl,
        'volumeDiscounts': JsonConverters.toJson(volumeDiscounts,'Map<int,double?>',context!)
    };

    getTypeName() => "ProductDto";
    TypeContext? context = _ctx;
}

class GetProduct implements IConvertible
{
    String? id;

    GetProduct({this.id});
    GetProduct.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        id = json['id'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'id': id
    };

    getTypeName() => "GetProduct";
    TypeContext? context = _ctx;
}

TypeContext _ctx = TypeContext(library: 'accounts.dev.healthmonix.com', types: <String, TypeInfo> {
    'ProductDto': TypeInfo(TypeOf.Class, create:() => ProductDto()),
    'Map<int,double?>': TypeInfo(TypeOf.Class, create:() => Map<int,double?>()),
    'GetProduct': TypeInfo(TypeOf.Class, create:() => GetProduct()),
});

Dart GetProduct 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.

GET /api/products/{id} HTTP/1.1 
Host: accounts.dev.healthmonix.com 
Accept: application/json
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: length

{"id":"String","name":"String","description":"String","longDescription":"String","details":"String","price":0,"productType":"String","year":0,"applicationId":"String","requiredProductId":"String","scope":"String","feature":"String","isVisible":false,"iconUrl":"String","volumeDiscounts":{"0":0}}