| GET | /api/automation/notification/{ObjectId}/list | ||
|---|---|---|---|
| GET | /api/automation/notification/{ObjectId}/list/standard | ||
| GET | /api/automation/notification/{ObjectId}/list/templated |
import datetime
import decimal
from marshmallow.fields import *
from servicestack import *
from typing import *
from dataclasses import dataclass, field
from dataclasses_json import dataclass_json, LetterCase, Undefined, config
from enum import Enum, IntEnum
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class AutomationModel:
# @ApiMember(Description="The unique automation Id", ParameterType="query")
automation_id: Optional[str] = None
"""
The unique automation Id
"""
# @ApiMember(Description="The automation type Id", ParameterType="query")
automation_type_id: Optional[str] = None
"""
The automation type Id
"""
# @ApiMember(Description="The automation type", ParameterType="query")
automation_type: Optional[str] = None
"""
The automation type
"""
# @ApiMember(Description="The object this automation applies to", ParameterType="query")
object_id: Optional[str] = None
"""
The object this automation applies to
"""
# @ApiMember(Description="The object name this automation applies to", ParameterType="query")
object_name: Optional[str] = None
"""
The object name this automation applies to
"""
# @ApiMember(Description="The Id of the object type that this automation applies to. ", ParameterType="query")
rms_table_ctx_id_object: Optional[str] = None
"""
The Id of the object type that this automation applies to.
"""
# @ApiMember(Description="The name of the object type that this automation applies to.", ParameterType="query")
rms_table_ctx_name: Optional[str] = None
"""
The name of the object type that this automation applies to.
"""
# @ApiMember(Description="A guid list containing the selected system action Id's that trigger this automation.", ParameterType="query")
action_list: Optional[List[str]] = None
"""
A guid list containing the selected system action Id's that trigger this automation.
"""
# @ApiMember(Description="A comma separated string of the selected system action names that trigger this automation.", ParameterType="query")
actions: Optional[str] = None
"""
A comma separated string of the selected system action names that trigger this automation.
"""
# @ApiMember(Description="Name of the automation.", ParameterType="query")
name: Optional[str] = None
"""
Name of the automation.
"""
# @ApiMember(Description="Description of the automation", ParameterType="query")
description: Optional[str] = None
"""
Description of the automation
"""
# @ApiMember(Description="Owner Contact Id", ParameterType="query")
owner_contact_id: Optional[str] = None
"""
Owner Contact Id
"""
# @ApiMember(Description="Record Status of the automation.", ParameterType="query")
record_status: Optional[str] = None
"""
Record Status of the automation.
"""
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class AutoNotificationModel(AutomationModel):
# @ApiMember(Description="Contact Id of the licensee this notification has been created for.", ParameterType="query")
contact_id_licensee: Optional[str] = None
"""
Contact Id of the licensee this notification has been created for.
"""
# @ApiMember(Description="Contact Role Group Id. If the notification is setup for people in a specified contact role group.", ParameterType="query")
contact_role_group_id: Optional[str] = None
"""
Contact Role Group Id. If the notification is setup for people in a specified contact role group.
"""
# @ApiMember(Description="Contact Role Id. If the notification is setup for people in a specified role.", ParameterType="query")
contact_role_id: Optional[str] = None
"""
Contact Role Id. 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")
contact_role_name: Optional[str] = None
"""
Contact Role Name. If the notification is setup for people in a specified role.
"""
# @ApiMember(Description="Contact Id. If the notification is setup for a specific person.", ParameterType="query")
contact_id: Optional[str] = None
"""
Contact Id. If the notification is setup for a specific person.
"""
# @ApiMember(Description="If true, then only contacts who are connected to the relevant object are notified.", ParameterType="query")
object_contact_connection_required: bool = False
"""
If true, then only contacts who are connected to the relevant object are notified.
"""
# @ApiMember(Description="Document Notification: If true, then the notification will include a link to download the document.", ParameterType="query")
allow_direct_access: bool = False
"""
Document Notification: If true, then the notification will include a link to download the document.
"""
# @ApiMember(Description="If true, the notification is sent as soon as it can be processed", ParameterType="query")
send_immediately: bool = False
"""
If true, the notification is sent as soon as it can be processed
"""
# @ApiMember(Description="If true, the notification is flagged and sent out when subscription/batch emails are next sent.", ParameterType="query")
batched: bool = False
"""
If true, the notification is flagged and sent out when subscription/batch emails are next sent.
"""
# @ApiMember(Description="Document Notification: If true, the notification is sent when a document has a status of draft.", ParameterType="query")
draft_status: bool = False
"""
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 final.", ParameterType="query")
final_status: bool = False
"""
Document Notification: If true, the notification is sent when a document has a status of final.
"""
# @ApiMember(Description="True if we want to include a report on an email notification. ", ParameterType="query")
include_report: bool = False
"""
True if we want to include a report on an email notification.
"""
# @ApiMember(Description="True if this notification is based on a template.", ParameterType="query")
is_template_notification: bool = False
"""
True if this notification is based on a template.
"""
# @ApiMember(Description="When Inserting a new notification we can have 1+ roles. They should be passed to this field when inserting.", ParameterType="query")
roles: Optional[List[str]] = None
"""
When Inserting a new notification we can have 1+ roles. They should be passed to this field when inserting.
"""
# @ApiMember(Description="Communication Type Id.", ParameterType="query")
communication_type_id: Optional[str] = None
"""
Communication Type Id.
"""
# @ApiMember(Description="Communication Type.", ParameterType="query")
communication_type: Optional[str] = None
"""
Communication Type.
"""
# @ApiMember(Description="If communication type is email, this is the subject of the email to be sent.", ParameterType="query")
subject: Optional[str] = None
"""
If communication type is email, this is the subject of the email to be sent.
"""
# @ApiMember(Description="This is the notification details to be sent.", ParameterType="query")
body: Optional[str] = None
"""
This is the notification details to be sent.
"""
# @ApiMember(Description="If true, we will include the relevant project URL in the notification.", ParameterType="query")
include_u_r_l: bool = False
"""
If true, we will include the relevant project URL in the notification.
"""
# @ApiMember(Description="The notification Id of a notification setup in Workflow Notification Management to use for the notification.", ParameterType="query")
notification_id: Optional[str] = None
"""
The notification Id of 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")
notification_name: Optional[str] = None
"""
The notification nameof a notification setup in Workflow Notification Management to use for the notification.
"""
# @ApiMember(Description="The suite id the notification is setup for", ParameterType="query")
suite_id: Optional[str] = None
"""
The suite id the notification is setup for
"""
# @ApiMember(Description="The suite name the notification is setup for", ParameterType="query")
suite_name: Optional[str] = None
"""
The suite name the notification is setup for
"""
# @ApiResponse(Description="List of (automation) notifications that are setup for an object.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class GetAutomationNotificationsForObjectResponse:
# @ApiMember(Description="List of (automation) notifications.")
notifications: Optional[List[AutoNotificationModel]] = None
"""
List of (automation) notifications.
"""
response_status: Optional[ResponseStatus] = None
# @Api(Description="Get (automation) notifications that are setup for an object")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class GetAutomationNotificationsForObject:
"""
Get (automation) notifications that are setup for an object
"""
# @ApiMember(Description="Object to retrieve (automation) notifications for.", ParameterType="path")
object_id: Optional[str] = None
"""
Object to retrieve (automation) notifications for.
"""
Python GetAutomationNotificationsForObject 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.
GET /api/automation/notification/{ObjectId}/list HTTP/1.1
Host: pfapi.pstpf.com.au
Accept: application/xml
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>