import 'package:servicestack/servicestack.dart';
import 'dart:typed_data';
class RuleValidationResult implements IConvertible
{
String? RuleCode;
String? Message;
String? Key;
String? Tag;
String? ErrorCode;
RuleValidationResult({this.RuleCode,this.Message,this.Key,this.Tag,this.ErrorCode});
RuleValidationResult.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
RuleCode = json['RuleCode'];
Message = json['Message'];
Key = json['Key'];
Tag = json['Tag'];
ErrorCode = json['ErrorCode'];
return this;
}
Map<String, dynamic> toJson() => {
'RuleCode': RuleCode,
'Message': Message,
'Key': Key,
'Tag': Tag,
'ErrorCode': ErrorCode
};
getTypeName() => "RuleValidationResult";
TypeContext? context = _ctx;
}
class ValidationErrorList implements IConvertible
{
List<RuleValidationResult>? ValidationErrors;
ValidationErrorList({this.ValidationErrors});
ValidationErrorList.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
ValidationErrors = JsonConverters.fromJson(json['ValidationErrors'],'List<RuleValidationResult>',context!);
return this;
}
Map<String, dynamic> toJson() => {
'ValidationErrors': JsonConverters.toJson(ValidationErrors,'List<RuleValidationResult>',context!)
};
getTypeName() => "ValidationErrorList";
TypeContext? context = _ctx;
}
class SubscriptionContactRoleModel implements IConvertible
{
/**
* Name of the role.
*/
// @ApiMember(DataType="string", Description="Name of the role.", Name="RoleName", ParameterType="query")
String? RoleName;
/**
* Short version of the role name.
*/
// @ApiMember(DataType="string", Description="Short version of the role name.", Name="RoleShortName", ParameterType="query")
String? RoleShortName;
/**
* Description of the role purpose.
*/
// @ApiMember(DataType="string", Description="Description of the role purpose.", Name="RoleDescription", ParameterType="query")
String? RoleDescription;
/**
* If true, the role will be pending for a contact until they accept it.
*/
// @ApiMember(DataType="bool", Description="If true, the role will be pending for a contact until they accept it.", Name="RequireContactsToAccept", ParameterType="query")
bool? RequireContactsToAccept;
/**
* Contact Types that may have this role.
*/
// @ApiMember(DataType="List<Guid>", Description="Contact Types that may have this role.", Name="ContactTypes", ParameterType="query")
List<String>? ContactTypes;
/**
* Role Filters this role should be added to.
*/
// @ApiMember(DataType="List<Guid>", Description="Role Filters this role should be added to.", Name="ListItemFilters", ParameterType="query")
List<String>? ListItemFilters;
SubscriptionContactRoleModel({this.RoleName,this.RoleShortName,this.RoleDescription,this.RequireContactsToAccept,this.ContactTypes,this.ListItemFilters});
SubscriptionContactRoleModel.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
RoleName = json['RoleName'];
RoleShortName = json['RoleShortName'];
RoleDescription = json['RoleDescription'];
RequireContactsToAccept = json['RequireContactsToAccept'];
ContactTypes = JsonConverters.fromJson(json['ContactTypes'],'List<String>',context!);
ListItemFilters = JsonConverters.fromJson(json['ListItemFilters'],'List<String>',context!);
return this;
}
Map<String, dynamic> toJson() => {
'RoleName': RoleName,
'RoleShortName': RoleShortName,
'RoleDescription': RoleDescription,
'RequireContactsToAccept': RequireContactsToAccept,
'ContactTypes': JsonConverters.toJson(ContactTypes,'List<String>',context!),
'ListItemFilters': JsonConverters.toJson(ListItemFilters,'List<String>',context!)
};
getTypeName() => "SubscriptionContactRoleModel";
TypeContext? context = _ctx;
}
class SaveContactRole extends ValidationErrorList implements ISubscription, IConvertible
{
/**
* Guid representing the external systems data source information.
*/
// @ApiMember(DataType="Guid", Description="Guid representing the external systems data source information.", IsRequired=true, Name="SuiteDataSourceInstanceId", ParameterType="query")
String? SuiteDataSourceInstanceId;
/**
* The unique key that represents the contact role on the external system.
*/
// @ApiMember(DataType="string", Description="The unique key that represents the contact role on the external system.", IsRequired=true, Name="AlternateKey", ParameterType="query")
String? AlternateKey;
/**
* Guid of the contact role 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 contact role object within Eros. If ObjectId is known, the external system may pass this instead of the alternate key.", Name="ObjectId", ParameterType="query")
String? ObjectId;
/**
* Object containing all details of the contact role to be inserted or updated.
*/
// @ApiMember(DataType="SubscriptionContactRoleModel", Description="Object containing all details of the contact role to be inserted or updated.", IsRequired=true, Name="ContactRole", ParameterType="query")
SubscriptionContactRoleModel? ContactRole;
bool? IgnoreValidation;
SaveContactRole({this.SuiteDataSourceInstanceId,this.AlternateKey,this.ObjectId,this.ContactRole,this.IgnoreValidation});
SaveContactRole.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
super.fromMap(json);
SuiteDataSourceInstanceId = json['SuiteDataSourceInstanceId'];
AlternateKey = json['AlternateKey'];
ObjectId = json['ObjectId'];
ContactRole = JsonConverters.fromJson(json['ContactRole'],'SubscriptionContactRoleModel',context!);
IgnoreValidation = json['IgnoreValidation'];
return this;
}
Map<String, dynamic> toJson() => super.toJson()..addAll({
'SuiteDataSourceInstanceId': SuiteDataSourceInstanceId,
'AlternateKey': AlternateKey,
'ObjectId': ObjectId,
'ContactRole': JsonConverters.toJson(ContactRole,'SubscriptionContactRoleModel',context!),
'IgnoreValidation': IgnoreValidation
});
getTypeName() => "SaveContactRole";
TypeContext? context = _ctx;
}
TypeContext _ctx = TypeContext(library: 'production_eros_platform_apisubscription.azurewebsites.net', types: <String, TypeInfo> {
'RuleValidationResult': TypeInfo(TypeOf.Class, create:() => RuleValidationResult()),
'ValidationErrorList': TypeInfo(TypeOf.Class, create:() => ValidationErrorList()),
'List<RuleValidationResult>': TypeInfo(TypeOf.Class, create:() => <RuleValidationResult>[]),
'SubscriptionContactRoleModel': TypeInfo(TypeOf.Class, create:() => SubscriptionContactRoleModel()),
'SaveContactRole': TypeInfo(TypeOf.Class, create:() => SaveContactRole()),
});
To override the Content-type in your clients, use the HTTP Accept Header, append the .xml suffix or ?format=xml
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /xml/reply/SaveContactRole HTTP/1.1
Host: production-eros-platform-apisubscription.azurewebsites.net
Accept: application/xml
Content-Type: application/xml
Content-Length: length
<SaveContactRole xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/Eros.Subtle.Canvara.WebAPIModel.ServiceModelSubscription">
<_x003C_ValidationErrors_x003E_k__BackingField xmlns="http://schemas.datacontract.org/2004/07/Eros.Saguna.Common.Library.ValidationEngine">
<RuleValidationResult>
<_x003C_ErrorCode_x003E_k__BackingField>String</_x003C_ErrorCode_x003E_k__BackingField>
<_x003C_Key_x003E_k__BackingField>String</_x003C_Key_x003E_k__BackingField>
<_x003C_Message_x003E_k__BackingField>String</_x003C_Message_x003E_k__BackingField>
<_x003C_RuleCode_x003E_k__BackingField>String</_x003C_RuleCode_x003E_k__BackingField>
<_x003C_Tag_x003E_k__BackingField>String</_x003C_Tag_x003E_k__BackingField>
</RuleValidationResult>
</_x003C_ValidationErrors_x003E_k__BackingField>
<AlternateKey>String</AlternateKey>
<ContactRole>
<ContactTypes xmlns:d3p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
<d3p1:guid>00000000-0000-0000-0000-000000000000</d3p1:guid>
</ContactTypes>
<ListItemFilters xmlns:d3p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
<d3p1:guid>00000000-0000-0000-0000-000000000000</d3p1:guid>
</ListItemFilters>
<RequireContactsToAccept>false</RequireContactsToAccept>
<RoleDescription>String</RoleDescription>
<RoleName>String</RoleName>
<RoleShortName>String</RoleShortName>
</ContactRole>
<ObjectId>00000000-0000-0000-0000-000000000000</ObjectId>
<SuiteDataSourceInstanceId>00000000-0000-0000-0000-000000000000</SuiteDataSourceInstanceId>
</SaveContactRole>
HTTP/1.1 200 OK Content-Type: application/xml Content-Length: length <ResponseStatus xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.servicestack.net/types"> <ErrorCode>String</ErrorCode> <Message>String</Message> <StackTrace>String</StackTrace> <Errors> <ResponseError> <ErrorCode>String</ErrorCode> <FieldName>String</FieldName> <Message>String</Message> <Meta xmlns:d4p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays"> <d4p1:KeyValueOfstringstring> <d4p1:Key>String</d4p1:Key> <d4p1:Value>String</d4p1:Value> </d4p1:KeyValueOfstringstring> </Meta> </ResponseError> </Errors> <Meta xmlns:d2p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays"> <d2p1:KeyValueOfstringstring> <d2p1:Key>String</d2p1:Key> <d2p1:Value>String</d2p1:Value> </d2p1:KeyValueOfstringstring> </Meta> </ResponseStatus>