| Requires any of the roles: | Client, Admin, Partner |
| GET | /campaign/actions/files | Get Campaign Action Files |
|---|
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 FormFieldOption:
value: Optional[str] = None
label: Optional[str] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class FormField:
id: int = 0
control_type: Optional[str] = None
label: Optional[str] = None
placeholder: Optional[str] = None
help: Optional[str] = None
name: Optional[str] = None
sort_order: int = 0
options: Optional[List[FormFieldOption]] = None
validation: Optional[List[str]] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class CampaignActionFile:
name: Optional[str] = None
file_type: Optional[str] = None
file_size: Optional[str] = None
extension: Optional[str] = None
upload_url: Optional[str] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class CampaignActions:
# @Required()
id: int = 0
# @Required()
# @References(typeof(Campaigns))
campaigns_id: int = 0
# @References(typeof(Actions))
actions_id: Optional[int] = None
button_name: Optional[str] = None
# @References(typeof(ActionTypes))
action_types_id: Optional[int] = None
description: Optional[str] = None
offer_order: Optional[int] = None
stand_out: Optional[bool] = None
# @Required()
public_access_guid: Optional[str] = None
form_meta: Optional[List[FormField]] = None
files: Optional[List[CampaignActionFile]] = None
sent_to_email_address: Optional[str] = None
cc_email_address: Optional[str] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class GetCampaignActionFiles:
# @Validate(Validator="NotNull")
campaigns_id: int = 0
campaign_actions_id: int = 0
Python GetCampaignActionFiles DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
GET /campaign/actions/files HTTP/1.1 Host: duengageapi.uat.scadsoftware.com Accept: text/jsv
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length
{
Id: 0,
CampaignsId: 0,
ActionsId: 0,
ButtonName: String,
ActionTypesId: 0,
Description: String,
OfferOrder: 0,
StandOut: False,
PublicAccessGuid: 00000000000000000000000000000000,
FormMeta:
[
{
Id: 0,
ControlType: String,
Label: String,
Placeholder: String,
Help: String,
Name: String,
SortOrder: 0,
Options:
[
{
Value: String,
Label: String
}
],
Validation:
[
String
]
}
],
Files:
[
{
Name: String,
FileType: String,
FileSize: String,
Extension: String,
UploadUrl: String
}
],
SentToEmailAddress: String,
CcEmailAddress: String
}