Class: CreateSend::Campaign
- Inherits:
- 
      CreateSend
      
        - Object
- CreateSend
- CreateSend::Campaign
 
- Defined in:
- lib/createsend/campaign.rb
Overview
Represents a campaign and provides associated functionality.
Constant Summary
Constants included from CreateSend
Instance Attribute Summary collapse
- 
  
    
      #campaign_id  ⇒ Object 
    
    
  
  
  
  
    
      readonly
    
    
  
  
  
  
  
  
    Returns the value of attribute campaign_id. 
Class Method Summary collapse
- 
  
    
      .create(auth, client_id, subject, name, from_name, from_email, reply_to, html_url, text_url, list_ids, segment_ids)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Creates a new campaign for a client. 
- 
  
    
      .create_from_template(auth, client_id, subject, name, from_name, from_email, reply_to, list_ids, segment_ids, template_id, template_content)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Creates a new campaign for a client, from a template. 
Instance Method Summary collapse
- 
  
    
      #bounces(date = "", page = 1, page_size = 1000, order_field = "date", order_direction = "asc")  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Retrieves the bounces for this campaign. 
- 
  
    
      #clicks(date = "", page = 1, page_size = 1000, order_field = "date", order_direction = "asc")  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Retrieves the subscriber clicks for this campaign. 
- 
  
    
      #delete  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Deletes this campaign. 
- 
  
    
      #email_client_usage  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Gets the email clients that subscribers used to open the campaign. 
- 
  
    
      #initialize(auth, campaign_id)  ⇒ Campaign 
    
    
  
  
  
    constructor
  
  
  
  
  
  
  
    A new instance of Campaign. 
- 
  
    
      #lists_and_segments  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Retrieves the lists and segments to which this campaaign will be (or was) sent. 
- 
  
    
      #opens(date = "", page = 1, page_size = 1000, order_field = "date", order_direction = "asc")  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Retrieves the opens for this campaign. 
- 
  
    
      #recipients(page = 1, page_size = 1000, order_field = "email", order_direction = "asc")  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Retrieves the recipients of this campaign. 
- 
  
    
      #send(confirmation_email, send_date = "immediately")  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Sends this campaign. 
- 
  
    
      #send_preview(recipients, personalize = "fallback")  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Sends a preview of this campaign. 
- 
  
    
      #spam(date = "", page = 1, page_size = 1000, order_field = "date", order_direction = "asc")  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Retrieves the spam complaints for this campaign. 
- 
  
    
      #summary  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Gets a summary of this campaign. 
- 
  
    
      #unschedule  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Unschedules this campaign if it is currently scheduled. 
- 
  
    
      #unsubscribes(date = "", page = 1, page_size = 1000, order_field = "date", order_direction = "asc")  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Retrieves the unsubscribes for this campaign. 
Constructor Details
#initialize(auth, campaign_id) ⇒ Campaign
Returns a new instance of Campaign.
| 6 7 8 9 | # File 'lib/createsend/campaign.rb', line 6 def initialize(auth, campaign_id) @campaign_id = campaign_id super end | 
Instance Attribute Details
#campaign_id ⇒ Object (readonly)
Returns the value of attribute campaign_id.
| 4 5 6 | # File 'lib/createsend/campaign.rb', line 4 def campaign_id @campaign_id end | 
Class Method Details
.create(auth, client_id, subject, name, from_name, from_email, reply_to, html_url, text_url, list_ids, segment_ids) ⇒ Object
Creates a new campaign for a client. client_id - String representing the ID of the client for whom the
campaign will be created.
subject - String representing the subject of the campaign. name - String representing the name of the campaign. from_name - String representing the from name for the campaign. from_email - String representing the from address for the campaign. reply_to - String representing the reply-to address for the campaign. html_url - String representing the URL for the campaign HTML content. text_url - String representing the URL for the campaign text content.
Note that text_url is optional and if nil or an empty string, text
content will be automatically generated from the HTML content.
list_ids - Array of Strings representing the IDs of the lists to
which the campaign will be sent.
segment_ids - Array of Strings representing the IDs of the segments to
which the campaign will be sent.
| 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 | # File 'lib/createsend/campaign.rb', line 27 def self.create(auth, client_id, subject, name, from_name, from_email, reply_to, html_url, text_url, list_ids, segment_ids) = { :body => { :Subject => subject, :Name => name, :FromName => from_name, :FromEmail => from_email, :ReplyTo => reply_to, :HtmlUrl => html_url, :TextUrl => text_url, :ListIDs => list_ids, :SegmentIDs => segment_ids }.to_json } cs = CreateSend.new auth response = cs.post "/campaigns/#{client_id}.json", response.parsed_response end | 
.create_from_template(auth, client_id, subject, name, from_name, from_email, reply_to, list_ids, segment_ids, template_id, template_content) ⇒ Object
Creates a new campaign for a client, from a template. client_id - String representing the ID of the client for whom the
campaign will be created.
subject - String representing the subject of the campaign. name - String representing the name of the campaign. from_name - String representing the from name for the campaign. from_email - String representing the from address for the campaign. reply_to - String representing the reply-to address for the campaign. list_ids - Array of Strings representing the IDs of the lists to
which the campaign will be sent.
segment_ids - Array of Strings representing the IDs of the segments to
which the campaign will be sent.
template_id - String representing the ID of the template on which
the campaign will be based.
template_content - Hash representing the content to be used for the
editable areas of the template. See documentation at
campaignmonitor.com/api/campaigns/#creating_a_campaign_from_template
for full details of template content format.
| 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 | # File 'lib/createsend/campaign.rb', line 62 def self.create_from_template(auth, client_id, subject, name, from_name, from_email, reply_to, list_ids, segment_ids, template_id, template_content) = { :body => { :Subject => subject, :Name => name, :FromName => from_name, :FromEmail => from_email, :ReplyTo => reply_to, :ListIDs => list_ids, :SegmentIDs => segment_ids, :TemplateID => template_id, :TemplateContent => template_content }.to_json } cs = CreateSend.new auth response = cs.post( "/campaigns/#{client_id}/fromtemplate.json", ) response.parsed_response end | 
Instance Method Details
#bounces(date = "", page = 1, page_size = 1000, order_field = "date", order_direction = "asc") ⇒ Object
Retrieves the bounces for this campaign.
| 169 170 171 172 173 | # File 'lib/createsend/campaign.rb', line 169 def bounces(date="", page=1, page_size=1000, order_field="date", order_direction="asc") paged_result_by_date("bounces", date, page, page_size, order_field, order_direction) end | 
#clicks(date = "", page = 1, page_size = 1000, order_field = "date", order_direction = "asc") ⇒ Object
Retrieves the subscriber clicks for this campaign.
| 148 149 150 151 152 | # File 'lib/createsend/campaign.rb', line 148 def clicks(date="", page=1, page_size=1000, order_field="date", order_direction="asc") paged_result_by_date("clicks", date, page, page_size, order_field, order_direction) end | 
#delete ⇒ Object
Deletes this campaign.
| 105 106 107 | # File 'lib/createsend/campaign.rb', line 105 def delete super "/campaigns/#{campaign_id}.json", {} end | 
#email_client_usage ⇒ Object
Gets the email clients that subscribers used to open the campaign
| 116 117 118 119 | # File 'lib/createsend/campaign.rb', line 116 def email_client_usage response = get "emailclientusage", {} response.map{|item| Hashie::Mash.new(item)} end | 
#lists_and_segments ⇒ Object
Retrieves the lists and segments to which this campaaign will be (or was) sent.
| 123 124 125 126 | # File 'lib/createsend/campaign.rb', line 123 def lists_and_segments response = get "listsandsegments", {} Hashie::Mash.new(response) end | 
#opens(date = "", page = 1, page_size = 1000, order_field = "date", order_direction = "asc") ⇒ Object
Retrieves the opens for this campaign.
| 141 142 143 144 145 | # File 'lib/createsend/campaign.rb', line 141 def opens(date="", page=1, page_size=1000, order_field="date", order_direction="asc") paged_result_by_date("opens", date, page, page_size, order_field, order_direction) end | 
#recipients(page = 1, page_size = 1000, order_field = "email", order_direction = "asc") ⇒ Object
Retrieves the recipients of this campaign.
| 129 130 131 132 133 134 135 136 137 138 | # File 'lib/createsend/campaign.rb', line 129 def recipients(page=1, page_size=1000, order_field="email", order_direction="asc") = { :query => { :page => page, :pagesize => page_size, :orderfield => order_field, :orderdirection => order_direction } } response = get 'recipients', Hashie::Mash.new(response) end | 
#send(confirmation_email, send_date = "immediately") ⇒ Object
Sends this campaign.
| 91 92 93 94 95 96 | # File 'lib/createsend/campaign.rb', line 91 def send(confirmation_email, send_date="immediately") = { :body => { :ConfirmationEmail => confirmation_email, :SendDate => send_date }.to_json } post "send", end | 
#send_preview(recipients, personalize = "fallback") ⇒ Object
Sends a preview of this campaign.
| 82 83 84 85 86 87 88 | # File 'lib/createsend/campaign.rb', line 82 def send_preview(recipients, personalize="fallback") = { :body => { :PreviewRecipients => recipients.kind_of?(String) ? [ recipients ] : recipients, :Personalize => personalize }.to_json } post "sendpreview", end | 
#spam(date = "", page = 1, page_size = 1000, order_field = "date", order_direction = "asc") ⇒ Object
Retrieves the spam complaints for this campaign.
| 162 163 164 165 166 | # File 'lib/createsend/campaign.rb', line 162 def spam(date="", page=1, page_size=1000, order_field="date", order_direction="asc") paged_result_by_date("spam", date, page, page_size, order_field, order_direction) end | 
#summary ⇒ Object
Gets a summary of this campaign
| 110 111 112 113 | # File 'lib/createsend/campaign.rb', line 110 def summary response = get "summary", {} Hashie::Mash.new(response) end | 
#unschedule ⇒ Object
Unschedules this campaign if it is currently scheduled.
| 99 100 101 102 | # File 'lib/createsend/campaign.rb', line 99 def unschedule = { :body => "" } post "unschedule", end | 
#unsubscribes(date = "", page = 1, page_size = 1000, order_field = "date", order_direction = "asc") ⇒ Object
Retrieves the unsubscribes for this campaign.
| 155 156 157 158 159 | # File 'lib/createsend/campaign.rb', line 155 def unsubscribes(date="", page=1, page_size=1000, order_field="date", order_direction="asc") paged_result_by_date("unsubscribes", date, page, page_size, order_field, order_direction) end |