| PUT | /api/automation/notification/{AutomationId} | ||
|---|---|---|---|
| POST | /api/automation/notification |
import 'package:servicestack/servicestack.dart';
class AutomationModel implements IConvertible
{
/**
* The unique automation Id
*/
// @ApiMember(Description="The unique automation Id", ParameterType="query")
String? AutomationId;
/**
* The automation type Id
*/
// @ApiMember(Description="The automation type Id", ParameterType="query")
String? AutomationTypeId;
/**
* The automation type
*/
// @ApiMember(Description="The automation type", ParameterType="query")
String? AutomationType;
/**
* The object this automation applies to
*/
// @ApiMember(Description="The object this automation applies to", ParameterType="query")
String? ObjectId;
/**
* The object name this automation applies to
*/
// @ApiMember(Description="The object name this automation applies to", ParameterType="query")
String? ObjectName;
/**
* The Id of the object type that this automation applies to.
*/
// @ApiMember(Description="The Id of the object type that this automation applies to. ", ParameterType="query")
String? RmsTableCtxIdObject;
/**
* The name of the object type that this automation applies to.
*/
// @ApiMember(Description="The name of the object type that this automation applies to.", ParameterType="query")
String? RmsTableCtxName;
/**
* A guid list containing the selected system action Id's that trigger this automation.
*/
// @ApiMember(Description="A guid list containing the selected system action Id's that trigger this automation.", ParameterType="query")
List<String>? ActionList;
/**
* A comma separated string of the selected system action names that trigger this automation.
*/
// @ApiMember(Description="A comma separated string of the selected system action names that trigger this automation.", ParameterType="query")
String? Actions;
/**
* Name of the automation.
*/
// @ApiMember(Description="Name of the automation.", ParameterType="query")
String? Name;
/**
* Description of the automation
*/
// @ApiMember(Description="Description of the automation", ParameterType="query")
String? Description;
/**
* Owner Contact Id
*/
// @ApiMember(Description="Owner Contact Id", ParameterType="query")
String? OwnerContactId;
/**
* Record Status of the automation.
*/
// @ApiMember(Description="Record Status of the automation.", ParameterType="query")
String? RecordStatus;
AutomationModel({this.AutomationId,this.AutomationTypeId,this.AutomationType,this.ObjectId,this.ObjectName,this.RmsTableCtxIdObject,this.RmsTableCtxName,this.ActionList,this.Actions,this.Name,this.Description,this.OwnerContactId,this.RecordStatus});
AutomationModel.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
AutomationId = json['AutomationId'];
AutomationTypeId = json['AutomationTypeId'];
AutomationType = json['AutomationType'];
ObjectId = json['ObjectId'];
ObjectName = json['ObjectName'];
RmsTableCtxIdObject = json['RmsTableCtxIdObject'];
RmsTableCtxName = json['RmsTableCtxName'];
ActionList = JsonConverters.fromJson(json['ActionList'],'List<String>',context!);
Actions = json['Actions'];
Name = json['Name'];
Description = json['Description'];
OwnerContactId = json['OwnerContactId'];
RecordStatus = json['RecordStatus'];
return this;
}
Map<String, dynamic> toJson() => {
'AutomationId': AutomationId,
'AutomationTypeId': AutomationTypeId,
'AutomationType': AutomationType,
'ObjectId': ObjectId,
'ObjectName': ObjectName,
'RmsTableCtxIdObject': RmsTableCtxIdObject,
'RmsTableCtxName': RmsTableCtxName,
'ActionList': JsonConverters.toJson(ActionList,'List<String>',context!),
'Actions': Actions,
'Name': Name,
'Description': Description,
'OwnerContactId': OwnerContactId,
'RecordStatus': RecordStatus
};
getTypeName() => "AutomationModel";
TypeContext? context = _ctx;
}
class AutoNotificationModel extends AutomationModel implements IConvertible
{
/**
* Contact Id of the licensee this notification has been created for.
*/
// @ApiMember(Description="Contact Id of the licensee this notification has been created for.", ParameterType="query")
String? ContactIdLicensee;
/**
* Contact Role Group Id. If the notification is setup for people in a specified contact role group.
*/
// @ApiMember(Description="Contact Role Group Id. If the notification is setup for people in a specified contact role group.", ParameterType="query")
String? ContactRoleGroupId;
/**
* Contact Role Id. If the notification is setup for people in a specified role.
*/
// @ApiMember(Description="Contact Role Id. If the notification is setup for people in a specified role.", ParameterType="query")
String? ContactRoleId;
/**
* Contact Role Name. If the notification is setup for people in a specified role.
*/
// @ApiMember(Description="Contact Role Name. If the notification is setup for people in a specified role.", ParameterType="query")
String? ContactRoleName;
/**
* Contact Id. If the notification is setup for a specific person.
*/
// @ApiMember(Description="Contact Id. If the notification is setup for a specific person.", ParameterType="query")
String? ContactId;
/**
* If true, then only contacts who are connected to the relevant object are notified.
*/
// @ApiMember(Description="If true, then only contacts who are connected to the relevant object are notified.", ParameterType="query")
bool? ObjectContactConnectionRequired;
/**
* Document Notification: If true, then the notification will include a link to download the document.
*/
// @ApiMember(Description="Document Notification: If true, then the notification will include a link to download the document.", ParameterType="query")
bool? AllowDirectAccess;
/**
* If true, the notification is sent as soon as it can be processed
*/
// @ApiMember(Description="If true, the notification is sent as soon as it can be processed", ParameterType="query")
bool? SendImmediately;
/**
* If true, the notification is flagged and sent out when subscription/batch emails are next sent.
*/
// @ApiMember(Description="If true, the notification is flagged and sent out when subscription/batch emails are next sent.", ParameterType="query")
bool? Batched;
/**
* Document Notification: If true, the notification is sent when a document has a status of draft.
*/
// @ApiMember(Description="Document Notification: If true, the notification is sent when a document has a status of draft.", ParameterType="query")
bool? DraftStatus;
/**
* Document Notification: If true, the notification is sent when a document has a status of final.
*/
// @ApiMember(Description="Document Notification: If true, the notification is sent when a document has a status of final.", ParameterType="query")
bool? FinalStatus;
/**
* True if we want to include a report on an email notification.
*/
// @ApiMember(Description="True if we want to include a report on an email notification. ", ParameterType="query")
bool? IncludeReport;
/**
* True if this notification is based on a template.
*/
// @ApiMember(Description="True if this notification is based on a template.", ParameterType="query")
bool? IsTemplateNotification;
/**
* When Inserting a new notification we can have 1+ roles. They should be passed to this field when inserting.
*/
// @ApiMember(Description="When Inserting a new notification we can have 1+ roles. They should be passed to this field when inserting.", ParameterType="query")
List<String>? Roles;
/**
* Communication Type Id.
*/
// @ApiMember(Description="Communication Type Id.", ParameterType="query")
String? CommunicationTypeId;
/**
* Communication Type.
*/
// @ApiMember(Description="Communication Type.", ParameterType="query")
String? CommunicationType;
/**
* If communication type is email, this is the subject of the email to be sent.
*/
// @ApiMember(Description="If communication type is email, this is the subject of the email to be sent.", ParameterType="query")
String? Subject;
/**
* This is the notification details to be sent.
*/
// @ApiMember(Description="This is the notification details to be sent.", ParameterType="query")
String? Body;
/**
* If true, we will include the relevant project URL in the notification.
*/
// @ApiMember(Description="If true, we will include the relevant project URL in the notification.", ParameterType="query")
bool? IncludeURL;
/**
* The notification Id of a notification setup in Workflow Notification Management to use for the notification.
*/
// @ApiMember(Description="The notification Id of a notification setup in Workflow Notification Management to use for the notification.", ParameterType="query")
String? NotificationId;
/**
* The notification nameof a notification setup in Workflow Notification Management to use for the notification.
*/
// @ApiMember(Description="The notification nameof a notification setup in Workflow Notification Management to use for the notification.", ParameterType="query")
String? NotificationName;
/**
* The suite id the notification is setup for
*/
// @ApiMember(Description="The suite id the notification is setup for", ParameterType="query")
String? SuiteId;
/**
* The suite name the notification is setup for
*/
// @ApiMember(Description="The suite name the notification is setup for", ParameterType="query")
String? SuiteName;
AutoNotificationModel({this.ContactIdLicensee,this.ContactRoleGroupId,this.ContactRoleId,this.ContactRoleName,this.ContactId,this.ObjectContactConnectionRequired,this.AllowDirectAccess,this.SendImmediately,this.Batched,this.DraftStatus,this.FinalStatus,this.IncludeReport,this.IsTemplateNotification,this.Roles,this.CommunicationTypeId,this.CommunicationType,this.Subject,this.Body,this.IncludeURL,this.NotificationId,this.NotificationName,this.SuiteId,this.SuiteName});
AutoNotificationModel.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
super.fromMap(json);
ContactIdLicensee = json['ContactIdLicensee'];
ContactRoleGroupId = json['ContactRoleGroupId'];
ContactRoleId = json['ContactRoleId'];
ContactRoleName = json['ContactRoleName'];
ContactId = json['ContactId'];
ObjectContactConnectionRequired = json['ObjectContactConnectionRequired'];
AllowDirectAccess = json['AllowDirectAccess'];
SendImmediately = json['SendImmediately'];
Batched = json['Batched'];
DraftStatus = json['DraftStatus'];
FinalStatus = json['FinalStatus'];
IncludeReport = json['IncludeReport'];
IsTemplateNotification = json['IsTemplateNotification'];
Roles = JsonConverters.fromJson(json['Roles'],'List<String>',context!);
CommunicationTypeId = json['CommunicationTypeId'];
CommunicationType = json['CommunicationType'];
Subject = json['Subject'];
Body = json['Body'];
IncludeURL = json['IncludeURL'];
NotificationId = json['NotificationId'];
NotificationName = json['NotificationName'];
SuiteId = json['SuiteId'];
SuiteName = json['SuiteName'];
return this;
}
Map<String, dynamic> toJson() => super.toJson()..addAll({
'ContactIdLicensee': ContactIdLicensee,
'ContactRoleGroupId': ContactRoleGroupId,
'ContactRoleId': ContactRoleId,
'ContactRoleName': ContactRoleName,
'ContactId': ContactId,
'ObjectContactConnectionRequired': ObjectContactConnectionRequired,
'AllowDirectAccess': AllowDirectAccess,
'SendImmediately': SendImmediately,
'Batched': Batched,
'DraftStatus': DraftStatus,
'FinalStatus': FinalStatus,
'IncludeReport': IncludeReport,
'IsTemplateNotification': IsTemplateNotification,
'Roles': JsonConverters.toJson(Roles,'List<String>',context!),
'CommunicationTypeId': CommunicationTypeId,
'CommunicationType': CommunicationType,
'Subject': Subject,
'Body': Body,
'IncludeURL': IncludeURL,
'NotificationId': NotificationId,
'NotificationName': NotificationName,
'SuiteId': SuiteId,
'SuiteName': SuiteName
});
getTypeName() => "AutoNotificationModel";
TypeContext? context = _ctx;
}
// @ApiResponse(Description="List of (automation) notifications that are setup for an object.")
class GetAutomationNotificationsForObjectResponse implements IConvertible
{
/**
* List of (automation) notifications.
*/
// @ApiMember(Description="List of (automation) notifications.")
List<AutoNotificationModel>? Notifications;
ResponseStatus? ResponseStatus;
GetAutomationNotificationsForObjectResponse({this.Notifications,this.ResponseStatus});
GetAutomationNotificationsForObjectResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
Notifications = JsonConverters.fromJson(json['Notifications'],'List<AutoNotificationModel>',context!);
ResponseStatus = JsonConverters.fromJson(json['ResponseStatus'],'ResponseStatus',context!);
return this;
}
Map<String, dynamic> toJson() => {
'Notifications': JsonConverters.toJson(Notifications,'List<AutoNotificationModel>',context!),
'ResponseStatus': JsonConverters.toJson(ResponseStatus,'ResponseStatus',context!)
};
getTypeName() => "GetAutomationNotificationsForObjectResponse";
TypeContext? context = _ctx;
}
/**
* Add or update an (automation) notification for an object
*/
// @Api(Description="Add or update an (automation) notification for an object")
class SaveAutoNotification implements IConvertible
{
/**
* Details of the (automation) notification to be added or updated.
*/
// @ApiMember(Description="Details of the (automation) notification to be added or updated.", ParameterType="query")
AutoNotificationModel? Notification;
/**
* Id of the automation.
*/
// @ApiMember(Description="Id of the automation.", ParameterType="path")
String? AutomationId;
SaveAutoNotification({this.Notification,this.AutomationId});
SaveAutoNotification.fromJson(Map<String, dynamic> json) { fromMap(json); }
fromMap(Map<String, dynamic> json) {
Notification = JsonConverters.fromJson(json['Notification'],'AutoNotificationModel',context!);
AutomationId = json['AutomationId'];
return this;
}
Map<String, dynamic> toJson() => {
'Notification': JsonConverters.toJson(Notification,'AutoNotificationModel',context!),
'AutomationId': AutomationId
};
getTypeName() => "SaveAutoNotification";
TypeContext? context = _ctx;
}
TypeContext _ctx = TypeContext(library: 'pfapi.pstpf.com.au', types: <String, TypeInfo> {
'AutomationModel': TypeInfo(TypeOf.Class, create:() => AutomationModel()),
'AutoNotificationModel': TypeInfo(TypeOf.Class, create:() => AutoNotificationModel()),
'GetAutomationNotificationsForObjectResponse': TypeInfo(TypeOf.Class, create:() => GetAutomationNotificationsForObjectResponse()),
'List<AutoNotificationModel>': TypeInfo(TypeOf.Class, create:() => <AutoNotificationModel>[]),
'SaveAutoNotification': TypeInfo(TypeOf.Class, create:() => SaveAutoNotification()),
});
Dart SaveAutoNotification DTOs
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 /api/automation/notification HTTP/1.1
Host: pfapi.pstpf.com.au
Accept: application/xml
Content-Type: application/xml
Content-Length: length
<SaveAutoNotification xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/Eros.Subtle.Canvara.WebAPIModel.ServiceModel">
<AutomationId>00000000-0000-0000-0000-000000000000</AutomationId>
<Notification xmlns:d2p1="http://schemas.datacontract.org/2004/07/Eros.Saguna.Common.WebAPIModel.Models">
<d2p1:ActionList xmlns:d3p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
<d3p1:guid>00000000-0000-0000-0000-000000000000</d3p1:guid>
</d2p1:ActionList>
<d2p1:Actions>String</d2p1:Actions>
<d2p1:AutomationId>00000000-0000-0000-0000-000000000000</d2p1:AutomationId>
<d2p1:AutomationType>String</d2p1:AutomationType>
<d2p1:AutomationTypeId>00000000-0000-0000-0000-000000000000</d2p1:AutomationTypeId>
<d2p1:Description>String</d2p1:Description>
<d2p1:Name>String</d2p1:Name>
<d2p1:ObjectId>00000000-0000-0000-0000-000000000000</d2p1:ObjectId>
<d2p1:ObjectName>String</d2p1:ObjectName>
<d2p1:OwnerContactId>00000000-0000-0000-0000-000000000000</d2p1:OwnerContactId>
<d2p1:RecordStatus>String</d2p1:RecordStatus>
<d2p1:RmsTableCtxIdObject>00000000-0000-0000-0000-000000000000</d2p1:RmsTableCtxIdObject>
<d2p1:RmsTableCtxName>String</d2p1:RmsTableCtxName>
<d2p1:AllowDirectAccess>false</d2p1:AllowDirectAccess>
<d2p1:Batched>false</d2p1:Batched>
<d2p1:Body>String</d2p1:Body>
<d2p1:CommunicationType>String</d2p1:CommunicationType>
<d2p1:CommunicationTypeId>00000000-0000-0000-0000-000000000000</d2p1:CommunicationTypeId>
<d2p1:ContactId>00000000-0000-0000-0000-000000000000</d2p1:ContactId>
<d2p1:ContactIdLicensee>00000000-0000-0000-0000-000000000000</d2p1:ContactIdLicensee>
<d2p1:ContactRoleGroupId>00000000-0000-0000-0000-000000000000</d2p1:ContactRoleGroupId>
<d2p1:ContactRoleId>00000000-0000-0000-0000-000000000000</d2p1:ContactRoleId>
<d2p1:ContactRoleName>String</d2p1:ContactRoleName>
<d2p1:DraftStatus>false</d2p1:DraftStatus>
<d2p1:FinalStatus>false</d2p1:FinalStatus>
<d2p1:IncludeReport>false</d2p1:IncludeReport>
<d2p1:IncludeURL>false</d2p1:IncludeURL>
<d2p1:IsTemplateNotification>false</d2p1:IsTemplateNotification>
<d2p1:NotificationId>00000000-0000-0000-0000-000000000000</d2p1:NotificationId>
<d2p1:NotificationName>String</d2p1:NotificationName>
<d2p1:ObjectContactConnectionRequired>false</d2p1:ObjectContactConnectionRequired>
<d2p1:Roles xmlns:d3p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
<d3p1:guid>00000000-0000-0000-0000-000000000000</d3p1:guid>
</d2p1:Roles>
<d2p1:SendImmediately>false</d2p1:SendImmediately>
<d2p1:Subject>String</d2p1:Subject>
<d2p1:SuiteId>00000000-0000-0000-0000-000000000000</d2p1:SuiteId>
<d2p1:SuiteName>String</d2p1:SuiteName>
</Notification>
</SaveAutoNotification>
HTTP/1.1 200 OK
Content-Type: application/xml
Content-Length: length
<GetAutomationNotificationsForObjectResponse xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/Eros.Subtle.Canvara.WebAPIModel.ServiceModel">
<Notifications xmlns:d2p1="http://schemas.datacontract.org/2004/07/Eros.Saguna.Common.WebAPIModel.Models">
<d2p1:AutoNotificationModel>
<d2p1:ActionList xmlns:d4p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
<d4p1:guid>00000000-0000-0000-0000-000000000000</d4p1:guid>
</d2p1:ActionList>
<d2p1:Actions>String</d2p1:Actions>
<d2p1:AutomationId>00000000-0000-0000-0000-000000000000</d2p1:AutomationId>
<d2p1:AutomationType>String</d2p1:AutomationType>
<d2p1:AutomationTypeId>00000000-0000-0000-0000-000000000000</d2p1:AutomationTypeId>
<d2p1:Description>String</d2p1:Description>
<d2p1:Name>String</d2p1:Name>
<d2p1:ObjectId>00000000-0000-0000-0000-000000000000</d2p1:ObjectId>
<d2p1:ObjectName>String</d2p1:ObjectName>
<d2p1:OwnerContactId>00000000-0000-0000-0000-000000000000</d2p1:OwnerContactId>
<d2p1:RecordStatus>String</d2p1:RecordStatus>
<d2p1:RmsTableCtxIdObject>00000000-0000-0000-0000-000000000000</d2p1:RmsTableCtxIdObject>
<d2p1:RmsTableCtxName>String</d2p1:RmsTableCtxName>
<d2p1:AllowDirectAccess>false</d2p1:AllowDirectAccess>
<d2p1:Batched>false</d2p1:Batched>
<d2p1:Body>String</d2p1:Body>
<d2p1:CommunicationType>String</d2p1:CommunicationType>
<d2p1:CommunicationTypeId>00000000-0000-0000-0000-000000000000</d2p1:CommunicationTypeId>
<d2p1:ContactId>00000000-0000-0000-0000-000000000000</d2p1:ContactId>
<d2p1:ContactIdLicensee>00000000-0000-0000-0000-000000000000</d2p1:ContactIdLicensee>
<d2p1:ContactRoleGroupId>00000000-0000-0000-0000-000000000000</d2p1:ContactRoleGroupId>
<d2p1:ContactRoleId>00000000-0000-0000-0000-000000000000</d2p1:ContactRoleId>
<d2p1:ContactRoleName>String</d2p1:ContactRoleName>
<d2p1:DraftStatus>false</d2p1:DraftStatus>
<d2p1:FinalStatus>false</d2p1:FinalStatus>
<d2p1:IncludeReport>false</d2p1:IncludeReport>
<d2p1:IncludeURL>false</d2p1:IncludeURL>
<d2p1:IsTemplateNotification>false</d2p1:IsTemplateNotification>
<d2p1:NotificationId>00000000-0000-0000-0000-000000000000</d2p1:NotificationId>
<d2p1:NotificationName>String</d2p1:NotificationName>
<d2p1:ObjectContactConnectionRequired>false</d2p1:ObjectContactConnectionRequired>
<d2p1:Roles xmlns:d4p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
<d4p1:guid>00000000-0000-0000-0000-000000000000</d4p1:guid>
</d2p1:Roles>
<d2p1:SendImmediately>false</d2p1:SendImmediately>
<d2p1:Subject>String</d2p1:Subject>
<d2p1:SuiteId>00000000-0000-0000-0000-000000000000</d2p1:SuiteId>
<d2p1:SuiteName>String</d2p1:SuiteName>
</d2p1:AutoNotificationModel>
</Notifications>
<ResponseStatus xmlns:d2p1="http://schemas.servicestack.net/types">
<d2p1:ErrorCode>String</d2p1:ErrorCode>
<d2p1:Message>String</d2p1:Message>
<d2p1:StackTrace>String</d2p1:StackTrace>
<d2p1:Errors>
<d2p1:ResponseError>
<d2p1:ErrorCode>String</d2p1:ErrorCode>
<d2p1:FieldName>String</d2p1:FieldName>
<d2p1:Message>String</d2p1:Message>
<d2p1:Meta xmlns:d5p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
<d5p1:KeyValueOfstringstring>
<d5p1:Key>String</d5p1:Key>
<d5p1:Value>String</d5p1:Value>
</d5p1:KeyValueOfstringstring>
</d2p1:Meta>
</d2p1:ResponseError>
</d2p1:Errors>
<d2p1:Meta xmlns:d3p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
<d3p1:KeyValueOfstringstring>
<d3p1:Key>String</d3p1:Key>
<d3p1:Value>String</d3p1:Value>
</d3p1:KeyValueOfstringstring>
</d2p1:Meta>
</ResponseStatus>
</GetAutomationNotificationsForObjectResponse>