Betting.WebApi

<back to all web services

AddLocationDevice

Requires Authentication
The following routes are available for this service:
POST/cmd/locations/devices/add
import 'package:servicestack/servicestack.dart';

class DeviceType
{
    static const DeviceType ClerkServicedKiosk = const DeviceType._(0);
    static const DeviceType PersonalOnline = const DeviceType._(1);
    static const DeviceType SelfServiceKiosk = const DeviceType._(2);
    static const DeviceType Unknown = const DeviceType._(-1);

    final int _value;
    const DeviceType._(this._value);
    int get value => _value;
    static List<DeviceType> get values => const [ClerkServicedKiosk,PersonalOnline,SelfServiceKiosk,Unknown];
}

class Device implements IConvertible
{
    String? id;
    String? name;
    bool? isActive;
    DeviceType? type;
    RecordDictionary<String,String>? integrationsData;

    Device({this.id,this.name,this.isActive,this.type,this.integrationsData});
    Device.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        id = json['id'];
        name = json['name'];
        isActive = json['isActive'];
        type = JsonConverters.fromJson(json['type'],'DeviceType',context!);
        integrationsData = JsonConverters.fromJson(json['integrationsData'],'RecordDictionary<String,String>',context!);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'id': id,
        'name': name,
        'isActive': isActive,
        'type': JsonConverters.toJson(type,'DeviceType',context!),
        'integrationsData': JsonConverters.toJson(integrationsData,'RecordDictionary<String,String>',context!)
    };

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

class AddLocationDevice implements IConvertible
{
    String? id;
    Device? device;

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

    fromMap(Map<String, dynamic> json) {
        id = json['id'];
        device = JsonConverters.fromJson(json['device'],'Device',context!);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'id': id,
        'device': JsonConverters.toJson(device,'Device',context!)
    };

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

class RecordDictionary<TKey,TVal> extends Map<TKey,TVal?> implements IConvertible
{
    RecordDictionary();
    RecordDictionary.fromJson(Map<String, dynamic> json) : super.fromJson(json);
    fromMap(Map<String, dynamic> json) {
        super.fromMap(json);
        return this;
    }

    Map<String, dynamic> toJson() => super.toJson();
    getTypeName() => "RecordDictionary<$TKey,$TVal>";
    TypeContext? context = _ctx;
}

TypeContext _ctx = TypeContext(library: 'api.sbbet.ath.cx', types: <String, TypeInfo> {
    'DeviceType': TypeInfo(TypeOf.Enum, enumValues:DeviceType.values),
    'Device': TypeInfo(TypeOf.Class, create:() => Device()),
    'RecordDictionary<String,String>': TypeInfo(TypeOf.Class, create:() => RecordDictionary<String,String>()),
    'AddLocationDevice': TypeInfo(TypeOf.Class, create:() => AddLocationDevice()),
    'RecordDictionary<TKey,TVal>': TypeInfo(TypeOf.GenericDef,create:() => RecordDictionary()),
});

Dart AddLocationDevice DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .other suffix or ?format=other

HTTP + OTHER

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

POST /cmd/locations/devices/add HTTP/1.1 
Host: api.sbbet.ath.cx 
Accept: text/jsonl
Content-Type: text/jsonl
Content-Length: length

{"id":"String","device":{"id":"String","name":"String","isActive":false,"type":0,"integrationsData":{"String":"String"}}}
HTTP/1.1 200 OK
Content-Type: text/jsonl
Content-Length: length

{"errorCode":"String","message":"String","stackTrace":"String","errors":[{"errorCode":"String","fieldName":"String","message":"String","meta":{"String":"String"}}],"meta":{"String":"String"}}