import 'package:servicestack/servicestack.dart';
class SubscriptionObjectModel implements ISubscription, IConvertible
{
/**
* Guid representing the external systems datasource information.
*/
// @ApiMember(DataType="Guid", Description="Guid representing the external systems datasource information.", IsRequired=true, Name="SuiteDataSourceInstanceId", ParameterType="query")
String? SuiteDataSourceInstanceId;
/**
* The unique key that represents the object on the external system.
*/
// @ApiMember(DataType="string", Description="The unique key that represents the object on the external system.", IsRequired=true, Name="AlternateKey", ParameterType="query")
String? AlternateKey;
/**
* Guid of the object within Eros. If ObjectId is known, the external system may pass this instead of the alternate key.
*/
// @ApiMember(DataType="Guid", Description="Guid of the object within Eros. If ObjectId is known, the external system may pass this instead of the alternate key.", Name="ObjectId", ParameterType="query")
String? ObjectId;
/**
* Guid of the RmsTableCtx within Eros. This is used if the alternate key is provided to identify the object to update.
*/
// @ApiMember(DataType="Guid", Description="Guid of the RmsTableCtx within Eros. This is used if the alternate key is provided to identify the object to update.", Name="RmsTableCtxId", ParameterType="query")
String? RmsTableCtxId;
/**
* Validation ensures that this object has a value in alternateKey or ObjectId, ignoring validation skips this requirement.
*/
// @ApiMember(DataType="bool", Description="Validation ensures that this object has a value in alternateKey or ObjectId, ignoring validation skips this requirement.", Name="IgnoreValidation", ParameterType="query")
bool? IgnoreValidation;
SubscriptionObjectModel({this.SuiteDataSourceInstanceId,this.AlternateKey,this.ObjectId,this.RmsTableCtxId,this.IgnoreValidation});
SubscriptionObjectModel.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
SuiteDataSourceInstanceId = json['SuiteDataSourceInstanceId'];
AlternateKey = json['AlternateKey'];
ObjectId = json['ObjectId'];
RmsTableCtxId = json['RmsTableCtxId'];
IgnoreValidation = json['IgnoreValidation'];
return this;
}
Map<String, dynamic> toJson() => {
'SuiteDataSourceInstanceId': SuiteDataSourceInstanceId,
'AlternateKey': AlternateKey,
'ObjectId': ObjectId,
'RmsTableCtxId': RmsTableCtxId,
'IgnoreValidation': IgnoreValidation
};
getTypeName() => "SubscriptionObjectModel";
TypeContext? context = _ctx;
}
/**
* Inserts an object connection between 2 valid objects.
*/
// @Api(Description="Inserts an object connection between 2 valid objects.")
class SaveObjectConnection implements IConvertible
{
/**
* Information to allow retrieval of the object from Eros that will be the 'From' object in the connection.
*/
// @ApiMember(DataType="SubscriptionObjectModel", Description="Information to allow retrieval of the object from Eros that will be the 'From' object in the connection.", IsRequired=true, Name="FromObject")
SubscriptionObjectModel? FromObject;
/**
* Information to allow retrieval of the object from Eros that will be the 'To' object in the connection.
*/
// @ApiMember(DataType="SubscriptionObjectModel", Description="Information to allow retrieval of the object from Eros that will be the 'To' object in the connection.", IsRequired=true, Name="ToObject")
SubscriptionObjectModel? ToObject;
/**
* Guid representing the Connection Method to use to connect the objects with.
*/
// @ApiMember(DataType="Guid", Description="Guid representing the Connection Method to use to connect the objects with.", IsRequired=true, Name="RmsTableCtxIdConnectionMethod")
String? RmsTableCtxIdConnectionMethod;
SaveObjectConnection({this.FromObject,this.ToObject,this.RmsTableCtxIdConnectionMethod});
SaveObjectConnection.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
FromObject = JsonConverters.fromJson(json['FromObject'],'SubscriptionObjectModel',context!);
ToObject = JsonConverters.fromJson(json['ToObject'],'SubscriptionObjectModel',context!);
RmsTableCtxIdConnectionMethod = json['RmsTableCtxIdConnectionMethod'];
return this;
}
Map<String, dynamic> toJson() => {
'FromObject': JsonConverters.toJson(FromObject,'SubscriptionObjectModel',context!),
'ToObject': JsonConverters.toJson(ToObject,'SubscriptionObjectModel',context!),
'RmsTableCtxIdConnectionMethod': RmsTableCtxIdConnectionMethod
};
getTypeName() => "SaveObjectConnection";
TypeContext? context = _ctx;
}
TypeContext _ctx = TypeContext(library: 'production_eros_platform_apisubscription.azurewebsites.net', types: <String, TypeInfo> {
'SubscriptionObjectModel': TypeInfo(TypeOf.Class, create:() => SubscriptionObjectModel()),
'SaveObjectConnection': TypeInfo(TypeOf.Class, create:() => SaveObjectConnection()),
});
Dart SaveObjectConnection 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
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /json/reply/SaveObjectConnection HTTP/1.1
Host: production-eros-platform-apisubscription.azurewebsites.net
Accept: application/json
Content-Type: application/json
Content-Length: length
{"FromObject":{"AlternateKey":"String","IgnoreValidation":false},"ToObject":{"AlternateKey":"String","IgnoreValidation":false}}
HTTP/1.1 200 OK Content-Type: application/json Content-Length: length {"ErrorCode":"String","Message":"String","StackTrace":"String","Errors":[{"ErrorCode":"String","FieldName":"String","Message":"String","Meta":{"String":"String"}}],"Meta":{"String":"String"}}