From 520c156f200aa7c829a94f9f7f5de47656b4d164 Mon Sep 17 00:00:00 2001 From: Grey Moore Date: Fri, 15 Mar 2024 10:26:11 -0400 Subject: [PATCH 1/3] fix typo on consent_content_version_external_id --- source/includes/_create_action_fields.md.erb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/source/includes/_create_action_fields.md.erb b/source/includes/_create_action_fields.md.erb index 90298604faa..4c03e83d4fe 100644 --- a/source/includes/_create_action_fields.md.erb +++ b/source/includes/_create_action_fields.md.erb @@ -11,7 +11,7 @@ | `<%= action_name %>[join_organisation]` | Whether or not the member has opted in to email communications from this campaign and organisation. This may be optional if you are using email confirmation for members actions. | | `<%= action_name %>[partnership_opt_ins]` | For partnership campaigns, whether or not this member has opted into communication from each partnership. This should be a JSON object like `{"123": true, "456": false}`, mapping partnership IDs to the opt-in status. | | `<%= action_name %>[eu_data_processing_consent]` | Whether or not member has given consent for GDPR data processing. This field must be true if the organisation requires data processing consent for user actions with `use_eu_data_processing_consent = true`. | -| `<%= action_name %>[consent_content_version_external_id]` | The External ID for the data processing consent content version the member has consented to on this action. The consent content version tracks what the privacy policy, terms of service, and checkbox label were at the time of this action. You can list available consent content versions via [this endpoint](https://developers.controlshiftlabs.com/#authenticated-rest-api-consent-content-versions). This field is required if the organisation requires data processing consent for user actions `use_eu_data_processing_consent = true`. | +| `<%= action_name %>[consent_content_version_external_id]` | The External ID for the data processing consent content version the member has consented to on this action. The consent content version tracks what the privacy policy, terms of service, and checkbox label were at the time of this action. You can list available consent content versions via [this endpoint](https://developers.controlshiftlabs.com/#authenticated-rest-api-consent-content-versions). This field is required if the organisation requires data processing consent for user actions. | | `<%= action_name %>[utm_source]` | UTM tracking field, optional. | | `<%= action_name %>[utm_campaign]` | UTM tracking field, optional. | | `<%= action_name %>[utm_content]` | UTM tracking field, optional. | From 80d3809b8836680703efa25022be748c01dbeff4 Mon Sep 17 00:00:00 2001 From: Grey Moore Date: Fri, 15 Mar 2024 10:18:03 -0400 Subject: [PATCH 2/3] revamp attendee-create documentation with the full set of fields, working JSON example, and separate Required column --- .../authenticated_api/_attendees.md.erb | 66 ++++++++++++++----- .../_common_action_fields.md.erb | 17 +++++ 2 files changed, 65 insertions(+), 18 deletions(-) create mode 100644 source/includes/authenticated_api/_common_action_fields.md.erb diff --git a/source/includes/authenticated_api/_attendees.md.erb b/source/includes/authenticated_api/_attendees.md.erb index b87b18f679c..b02c40d0d46 100644 --- a/source/includes/authenticated_api/_attendees.md.erb +++ b/source/includes/authenticated_api/_attendees.md.erb @@ -75,26 +75,38 @@ Find an attendee by email address. Once you have obtained the attendee's id you
### Create +> POST /api/v1/events/deliver-the-petition-to-the-wizard/attendees -Creates a new attendee for the specified event. This API endpoint can be used to record externally collected RSVPs for -a particular event within your instance of the ControlShift platform. - -All of the same post-RSVP actions that the platform usually supports including webhooks, CRM syncs, and other integrations -will still be triggered, in the same way they are for normal RSVPs. - -For organisations that require email confirmation, a confirmation email will be sent to the action taker. - -<%= partial 'includes/create_action_fields.md.erb', locals: { action_name: 'attendee' } %> - -`POST /api/v1/events/deliver-the-petition-to-the-wizard/attendees/` - -
- -#### POST body - -`attendee[first_name]=Ada&attendee[last_name]=Lovelace&attendee[email]=ada@lovelace.com&attendee[postcode]=12345` +```json +{ + "attendee": { + "attending_status": "attending", + "notification_level": "all_messages", + "first_name": "Ada", + "last_name": "Lovelace", + "email": "ada@lovelace.com", + "postcode": "12345", + "phone_number": "555-555-555", + "locale": "en-GB", + "country": "GB", + "email_opt_in_type_external_id": "canvass-signature-2022", + "join_organisation": true, + "partnership_opt_ins": { + "123": true, + "456": false + }, + "eu_data_processing_consent": true, + "consent_content_version_external_id": "revised-terms-2022-february", + "utm_source": "facebook", + "utm_medium": "button", + "utm_campaign": "infrastructure-petition-delivery-2022", + "utm_term": null, + "utm_content": null + } +} +``` -> POST response body for create +> Response body ```json { @@ -152,6 +164,24 @@ For organisations that require email confirmation, a confirmation email will be } ``` +Creates a new attendee for the specified event. This API endpoint can be used to record externally collected RSVPs for +a particular event within your instance of the ControlShift platform. + +`POST /api/v1/events/deliver-the-petition-to-the-wizard/attendees/` + +All of the same post-RSVP actions that the platform usually supports including webhooks, CRM syncs, and other integrations +will still be triggered, in the same way they are for normal RSVPs. + +For organisations that require email confirmation, a confirmation email will be sent to the action taker. + +The request body should be a JSON block containing one `"attendee"` object, which can have the following properties: + +| Field | Description | Required? | +| ------------------------- | ------------------------------------------------------------------------ | --------- | +| attending_status | Whether the member is attending the event. One of `attending`, `not_attending`, `attended`, `confirmed`, or `no_show`. | yes +| notification_level | Email notification preference for the event forum. One of `all_messages` (an email for every post), `none` (no emails), or `pending` (preference will be determined during email confirmation). | yes +<%= partial 'includes/authenticated_api/common_action_fields.md.erb' %> +
### Update email opt in type diff --git a/source/includes/authenticated_api/_common_action_fields.md.erb b/source/includes/authenticated_api/_common_action_fields.md.erb new file mode 100644 index 00000000000..8bd92043858 --- /dev/null +++ b/source/includes/authenticated_api/_common_action_fields.md.erb @@ -0,0 +1,17 @@ + first_name | The first name of the member who took action | yes +| last_name | The last name of the member who took action | yes +| email | The email address of the member who took action | yes +| postcode | The postal or zip code of the member. Depending on your configuration, this may be validated for your country. | Depends on platform settings +| phone_number | The phone number of the member who took action | Depends on platform settings +| locale | The language and localization setting of the member who has taken action. This is specified as an [ISO_639-1](https://en.wikipedia.org/wiki/List_of_ISO_639-1_codes) two-character language code combined with an optional [ISO 3166](https://en.wikipedia.org/wiki/List_of_ISO_3166_country_codes) two character country code. For eg `en-US` or `en`. | no; default is `en` +| country | The country specified as an [ISO 3166](https://en.wikipedia.org/wiki/List_of_ISO_3166_country_codes) two character country code. | Depends on platform settings +| email_opt_in_type_external_id | The External ID for the ControlShift email opt in type to use for this action. The email opt in type must have "external" context. You can list available email opt in types with [this endpoint](https://developers.controlshiftlabs.com/#authenticated-rest-api-email-opt-in-types). | yes +| join_organisation | Whether or not the member has opted in to email communications from this campaign and organisation. | yes, unless "defer opt-in to confirmation email" is enabled +| partnership_opt_ins | For partnership campaigns, whether or not this member has opted into communication from each partnership. This should be a JSON object like `{"123": true, "456": false}`, mapping partnership IDs to the opt-in status. | no +| eu_data_processing_consent | Whether or not member has given consent for GDPR data processing. This field must be true if the organisation requires data processing consent for user actions with `use_eu_data_processing_consent = true`. | yes, if data processing consent is enabled +| consent_content_version_external_id | The External ID for the data processing consent content version the member has consented to on this action. The consent content version tracks what the privacy policy, terms of service, and checkbox label were at the time of this action. You can list available consent content versions via [this endpoint](https://developers.controlshiftlabs.com/#authenticated-rest-api-consent-content-versions). | yes, if data processing consent is enabled +| utm_source | UTM tracking field | no +| utm_campaign | UTM tracking field | no +| utm_content | UTM tracking field | no +| utm_medium | UTM tracking field | no +| utm_term | UTM tracking field | no From ebcd1f6c8e1c4a939010848e05bb28a0b69e0f6d Mon Sep 17 00:00:00 2001 From: Grey Moore Date: Fri, 15 Mar 2024 11:00:39 -0400 Subject: [PATCH 3/3] use new style for signature create table too --- source/includes/_create_action_fields.md.erb | 19 ---------- .../authenticated_api/_signatures.md.erb | 37 +++++++++---------- 2 files changed, 17 insertions(+), 39 deletions(-) delete mode 100644 source/includes/_create_action_fields.md.erb diff --git a/source/includes/_create_action_fields.md.erb b/source/includes/_create_action_fields.md.erb deleted file mode 100644 index 4c03e83d4fe..00000000000 --- a/source/includes/_create_action_fields.md.erb +++ /dev/null @@ -1,19 +0,0 @@ -| Field | Explanation | -| ------------------------- | ------------------------------------------------------------------------ | -| `<%= action_name %>[first_name]` | The first name of the member who took action, required. | -| `<%= action_name %>[last_name]` | The last name of the member who took action, required. | -| `<%= action_name %>[email]` | The email address of the member who took action, required. | -| `<%= action_name %>[postcode]` | The postal or zip code of the member. Depending on your platform settings this may be a required field. Depending on your configuration, this may be validated for your country. | -| `<%= action_name %>[phone_number]` | The phone number of the member who took action. Depending on your platform settings this may be a required field. | -| `<%= action_name %>[locale]` | The language and localization setting of the member who has taken action. This is specified as an [ISO_639-1](https://en.wikipedia.org/wiki/List_of_ISO_639-1_codes) two-character language code combined with an optional [ISO 3166](https://en.wikipedia.org/wiki/List_of_ISO_3166_country_codes) two character country code. For eg `en-US` or `en`. This is an optional field, if not provided will be set to `en` by default. | -| `<%= action_name %>[country]` | The country specified as an [ISO 3166](https://en.wikipedia.org/wiki/List_of_ISO_3166_country_codes) two character country code. This may be optional or required depending on your platform configuration. | -| `<%= action_name %>[email_opt_in_type_external_id]` | The External ID for the ControlShift email opt in type to use for this action. The email opt in type must have "external" context. You can list available email opt in types with [this endpoint](https://developers.controlshiftlabs.com/#authenticated-rest-api-email-opt-in-types). This is a required field. | -| `<%= action_name %>[join_organisation]` | Whether or not the member has opted in to email communications from this campaign and organisation. This may be optional if you are using email confirmation for members actions. | -| `<%= action_name %>[partnership_opt_ins]` | For partnership campaigns, whether or not this member has opted into communication from each partnership. This should be a JSON object like `{"123": true, "456": false}`, mapping partnership IDs to the opt-in status. | -| `<%= action_name %>[eu_data_processing_consent]` | Whether or not member has given consent for GDPR data processing. This field must be true if the organisation requires data processing consent for user actions with `use_eu_data_processing_consent = true`. | -| `<%= action_name %>[consent_content_version_external_id]` | The External ID for the data processing consent content version the member has consented to on this action. The consent content version tracks what the privacy policy, terms of service, and checkbox label were at the time of this action. You can list available consent content versions via [this endpoint](https://developers.controlshiftlabs.com/#authenticated-rest-api-consent-content-versions). This field is required if the organisation requires data processing consent for user actions. | -| `<%= action_name %>[utm_source]` | UTM tracking field, optional. | -| `<%= action_name %>[utm_campaign]` | UTM tracking field, optional. | -| `<%= action_name %>[utm_content]` | UTM tracking field, optional. | -| `<%= action_name %>[utm_medium]` | UTM tracking field, optional. | -| `<%= action_name %>[utm_term]` | UTM tracking field, optional. | diff --git a/source/includes/authenticated_api/_signatures.md.erb b/source/includes/authenticated_api/_signatures.md.erb index af99ed5f4ce..2e62273a210 100644 --- a/source/includes/authenticated_api/_signatures.md.erb +++ b/source/includes/authenticated_api/_signatures.md.erb @@ -133,26 +133,7 @@ The JSON response has a single "signature" object, which may include the followi ### Create -Creates a new signature for the specified petition. This API endpoint can be used to record externally collected signatures for -a particular petition within your instance of the ControlShift platform. - -All of the same post-signature actions that the platform usually supports including webhooks, CRM syncs, and other integrations -will still be triggered, in the same way they are for normal signatures. - -For organisations that require email confirmation, a confirmation email will be sent to the action taker. - -<%= partial 'includes/create_action_fields.md.erb', locals: { action_name: 'signature' } %> - -`POST /api/v1/petitions/no-taxes-on-tea/signatures/` - -
- - -#### POST body - -`signature[first_name]=Ada&signature[last_name]=Lovelave&signature[email]=ada@lovelace.com&signature[postcode]=12345` - -> POST response body for create +> Response body ```json { @@ -208,6 +189,22 @@ For organisations that require email confirmation, a confirmation email will be } ``` +Creates a new signature for the specified petition. This API endpoint can be used to record externally collected signatures for +a particular petition within your instance of the ControlShift platform. + +`POST /api/v1/petitions/no-taxes-on-tea/signatures/` + +All of the same post-signature actions that the platform usually supports including webhooks, CRM syncs, and other integrations +will still be triggered, in the same way they are for normal signatures. + +For organisations that require email confirmation, a confirmation email will be sent to the action taker. + +The request body should be a JSON block containing one `"signature"` object, which can have the following properties: + +| Field | Description | Required? | +| ------------------------- | ------------------------------------------------------------------------ | --------- | +<%= partial 'includes/authenticated_api/common_action_fields.md.erb' %> +
### Update email opt in type