Canny is a customer feedback management tool which captures, organizes, and analyzes product feedback in one place to help you make informed product decisions.
RudderStack supports Canny as a destination to which you can seamlessly send your event data.
Getting started
Before configuring Canny as a destination in RudderStack, verify if the source platform is supported by Canny by referring to the table below:
Connection Mode | Web | Mobile | Server |
---|---|---|---|
Device mode | - | - | - |
Cloud mode | Supported | Supported | Supported |
Once you have confirmed that the source platform supports sending events to Canny, follow these steps:
- From your RudderStack dashboard, add a source. Then, from the list of destinations, select Canny.
- Assign a name to the destination and click on Continue.
Connection settings
To successfully configure Canny as a destination, you will need to configure the following settings:
- API Key: Enter your API key from the Canny dashboard.
Event settings
- Mapping to trigger Canny Events for the respective Event: Enter the event name and choose the Canny event from the dropdown to be triggered when that event is called.
Identify
You can use the identify
call to create or update a user in Canny.
A sample identify
call is shown below:
rudderanalytics.identify("1hKOmRA4el9Zt1WSfVJIVo4GRlm", { "name": "Alex Keener", "email": "alex@example.com", "gender": "Male", "profession": "singer-songwriter", "companies": [{ "created": "2020-01-23T04:56:07.890Z", "customFields": { "field1": "value1", }, "id": "company123", "monthlySpend": 500.00, "name": "company name" }]});
Property mappings
The following table lists the mappings between RudderStack and Canny properties:
RudderStack property | Canny property | Presence | Data type |
---|---|---|---|
userId /traits.userId /traits.id /context.traits.userId /context.traits.id | userId | Required | String |
context.traits.name /traits.name | name | Required | String |
context.traits.email /traits.email /properties.email | email | Optional | String |
context.traits /traits (after removing email and name ) | customFields | Optional | Object |
originalTimestamp /timestamp | created | Optional | ISO 8601 Timestamp |
context.traits.avatarURL /traits.avatarURL | avatarURL | Optional | String |
context.traits.companies /traits.companies | companies | Optional | Array of object (in company objects id and name are the only required fields) |
Track
You can create the following events using the track
call:
RudderStack retrieves the user data using userId
or email
and uses that information to create post or vote.
A sample track
call is shown below:
rudderanalytics.track("Submit", { boardId: "62de88676bc28b44eeef25dd", details: "Require new feature", title: "New Feature", eta: "10.08.2022", priority: "High"})
Property mappings for Create post event
The following table lists the mappings between RudderStack and Canny properties for the Create post event:
RudderStack property | Canny property | Presence | Data type | Notes |
---|---|---|---|---|
properties.boardID /properties.boardId /properties.board.id | boardID | Required | String | - |
Collect from externalId or retrieve user API call | authorID | Required | String | - |
properties.details | details | Required | String | - |
properties.title | title | Required | String | - |
properties.byID /properties.byId /properties.by.id | byID | Optional | String | - |
properties.categoryID /properties.categoryId /properties.category.id | categoryID | Optional | String | - |
properties.customFields | customFields | Optional | Object | Ensure that you create the custom fields in Canny dashboard to send the event successfully. |
properties.eta | eta | Required if etaPublic is present. | String | Should be in the MM/YYYY format. |
properties.etaPublic | etaPublic | Required if eta is present. | Boolean | - |
properties.imageURLs | imageURLs | Optional | Array of strings | - |
Property mappings for Create vote event
The following table lists the mappings between RudderStack and Canny properties for the Create vote event:
RudderStack property | Canny property | Presence | Data type |
---|---|---|---|
properties.postId /properties.postID /properties.post.id | postID | Required | String |
Collect from externalId or retrieve user API call | voterID | Required | String |
externalId
is cannyUserId
.FAQ
Where can I find the Canny API Key?
To find the Canny API Key:
- Log into your Canny account.
- Go to Settings > API & Webhooks under your profile, as shown:
How to create custom fields in the Canny dashboard?
To create custom fields in Canny Dashboard:
- Log into your Canny account.
- Under your profile, navigate to Settings > Post Fields > Create New Field.
- Enter the field name and click on Create.
- Navigate to Boards and select the desired Board from the dropdown.
- Select Create Post Form > Add Fields in the Fields section.
- Select the relevant Post Field from the dropdown.
- Enter details and click Save.
Contact us
For more information on the topics covered on this page, email us or start a conversation in our Slack community.