Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: accoil analytics destination #3873

Open
wants to merge 2 commits into
base: develop
Choose a base branch
from

Conversation

accoilmj
Copy link

@accoilmj accoilmj commented Nov 12, 2024

What are the changes introduced in this PR?

Adds a new destination for 'Accoil Analytics'.

I'm not sure what new readability format mentioned in the checklist refers to; please advise.

Please explain the objectives of your changes below

Add destination for 'Accoil analytics' so that it shows up in the UI for selection as a destination on sources in Rudderstack and sends events to our system.

All events go to a "/segment" API and we support: track, page, screen, identify, group. We do not support batch natively but I was hoping that the handling here where it loops over them and returns a separate request will work. Please advise if not.

Documentation PR is here: rudderlabs/rudderstack-docs#1196
UI PR is here: rudderlabs/rudder-integrations-config#1807

Any changes to existing capabilities/behaviour, mention the reason & what are the changes ?

N/A

Any new dependencies introduced with this change?

N/A

Any new generic utility introduced or modified. Please explain the changes.

N/A

Any technical or performance related pointers to consider with the change?

N/A

@coderabbitai review


Developer checklist

  • My code follows the style guidelines of this project

  • No breaking changes are being introduced.

  • All related docs linked with the PR?

  • All changes manually tested?

  • Any documentation changes needed with this change?

  • Is the PR limited to 10 file changes?

  • Is the PR limited to one linear task?

  • Are relevant unit and component test-cases added in new readability format?

Reviewer checklist

  • Is the type of change in the PR title appropriate as per the changes?

  • Verified that there are no credentials or confidential data exposed with the changes.

@contributor-support
Copy link

Thank you @accoilmj for contributing this PR.
Please sign the Contributor License Agreement (CLA) before merging.

@accoilmj accoilmj force-pushed the accoil-analytics-destination branch from d516a61 to 7b8cc26 Compare November 12, 2024 09:56
@accoilmj
Copy link
Author

Thank you @accoilmj for contributing this PR. Please sign the Contributor License Agreement (CLA) before merging.

I signed and submitted this form but it reported an error it was unable to update the PR status:

CLA signed. But we were unable to update the PR status.

We failed to remove 'Pending CLA' label automatically from your PRs.

Next steps:
1. Please make sure you submitted the correct information

    Your GitHub Username: accoilmj
    Your Email: mj@accoil.com

2. Please ask PR reviewers to manually verify your CLA submission.< br />

Note: Only one CLA submission is required, irrespective of number of PRs you raised. 

@accoilmj
Copy link
Author

Hi @manish339k. Thanks for taking the time to review. This wasn't really ready for review yet, it was just what I threw together to try and get it working locally but it won't run for me so I uploaded this in the hopes maybe something stood out. I raised this in the Slack workspace: https://rudderstack.slack.com/archives/C026KTP7KPW/p1731403790462469

When I try to run this locally I just see this anytime I call it:

[
    {
        "metadata": {
            "destinationId": "destId",
            "workspaceId": "wspId"
        },
        "statusCode": 500,
        "error": "Cannot find module '../v1/destinations/accoil_analytics/transform'\nRequire stack:\n- <snip>/rudder-transformer/dist/src/services/misc.js\n- <snip>/rudder-transformer/dist/src/helpers/fetchHandlers.js\n- <snip>/rudder-transformer/dist/src/services/destination/nativeIntegration.js\n- <snip>/rudder-transformer/dist/src/helpers/serviceSelector.js\n- <snip>/rudder-transformer/dist/src/controllers/delivery.js\n- <snip>/rudder-transformer/dist/src/routes/delivery.js\n- <snip>/rudder-transformer/dist/src/routes/index.js\n- <snip>/rudder-transformer/dist/src/index.js",
        "statTags": {
            "errorCategory": "transformation"
        }
    }
]

Would any of the items you pointed out above potentially be the cause?

@accoilmj accoilmj force-pushed the accoil-analytics-destination branch from 7b8cc26 to 0d0570f Compare November 14, 2024 03:26
@accoilmj
Copy link
Author

I've pushed fixes for most of these items but it still doesn't seem to run locally

@manish339k
Copy link
Contributor

manish339k commented Nov 14, 2024

I've pushed fixes for most of these items but it still doesn't seem to run locally

@accoilmj Can you please check if you are sending "cdkV2Enabled": true in the payload?

"destination": {
            "DestinationDefinition": {
                "Config": {
                    "cdkV2Enabled": true
                }
            },
            "Config": {}
}

@accoilmj
Copy link
Author

Excellent @manish339k ! I wasn't setting that and now that I am it is working with a 200 and I can see my transformed JSON. Great. I can continue dev and testing on this now. Many thanks!

Apologies if I missed that in the setup instructions

@accoilmj accoilmj force-pushed the accoil-analytics-destination branch from 2b3a9b6 to 0a933b0 Compare November 18, 2024 01:56
@manish339k
Copy link
Contributor

@accoilmj, Could you please share the API documentation for Accoil analytics destination?

@accoilmj
Copy link
Author

@accoilmj, Could you please share the API documentation for Accoil analytics destination?

@manish339k we don't really have a published API for it. At its core it simply expects Segment (or Segment like) formatted payloads to the endpoint https://in.accoil.com/segment. There is doc on our Segment integration and the types of calls we accept here: https://segment.com/docs/connections/destinations/catalog/actions-accoil-analytics/

@accoilmj accoilmj force-pushed the accoil-analytics-destination branch 2 times, most recently from e790f3f to 5b571a9 Compare November 18, 2024 23:17
@accoilmj accoilmj marked this pull request as ready for review November 19, 2024 00:46
@accoilmj accoilmj requested review from a team and sivashanmukh as code owners November 19, 2024 00:46
@accoilmj accoilmj force-pushed the accoil-analytics-destination branch from 5b571a9 to 3c4cd08 Compare November 19, 2024 03:26
@manish339k
Copy link
Contributor

@accoilmj Could you please provide a test account so that we can validate and test the changes on our end?

@accoilmj
Copy link
Author

@accoilmj Could you please provide a test account so that we can validate and test the changes on our end?

Hi @manish339k you should be able to sign up yourself at https://app.accoil.com/ just click 'Sign up' and fill in your details. After signing up you'll have a trial account and you can go to Settings > Account > General and copy the API key.

@accoilmj
Copy link
Author

@manish339k were you able to get in and get the key needed for testing? Let me know if I can help.

@manish339k
Copy link
Contributor

@accoilmj I got the API key and am able to send the event. However, after sending the event, where can I verify the event delivery? Where should I check in the dashboard? I am seeing only one single page with API key after login.

I have one more question - I'm getting a 202 Accepted response even after sending the event without the authorization header. Is this expected behavior?

Screenshot 2024-11-28 at 11 16 27 AM

@accoilmj
Copy link
Author

@manish339k the system should recognise the data was received within 30 minutes and take you into the product and stop showing you that setup page. After that you should be able to create a profile and see events.

If it's taking longer than that then something is going wrong. I can look into where the events may be going.

As for whether it accepts it without the authorization header that is expected. Currently favours throughput so it accepts all calls and processes it later in batches so unfortunately you can't necessarily tell that it will wind up being rejected.

@accoilmj
Copy link
Author

@manish339k it looks like data has started showing up so you should be able to get into the app now and click "Profiles" in the top nav then create a new profile to see the data.

@manish339k
Copy link
Contributor

@accoilmj Thanks, I was missing the step of converting the API key to Base64 encoding. Now I am able to see the events in the dashboard. I will test, verify, and review the PR.

@accoilmj
Copy link
Author

Thanks @manish339k

@accoilmj
Copy link
Author

Hi @manish339k just checking in if there's anything further I need to work on here? Thanks.

@devops-github-rudderstack
Copy link
Contributor

This PR is considered to be stale. It has been open for 20 days with no further activity thus it is going to be closed in 7 days. To avoid such a case please consider removing the stale label manually or add a comment to the PR.

@accoilmj
Copy link
Author

accoilmj commented Jan 7, 2025

Rebased and pushed to fix staleness

condition: $.context.messageType == {{$.EventType.GROUP}}
template: |
$.context.payload.anonymousId = .message.anonymousId;
$.context.payload.userId = .message.().({{{{$.getGenericPaths("userId")}}}});
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Are we mapping anonymous id and user id separately?
According to the doc anonymous id may be mapped to user id https://github.com/rudderlabs/rudderstack-docs/pull/1196/files#diff-e78f3c4a5eb7832b1714403b0ee37296a8ee585d52e0f3f575b224db82cfa8c5R80

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good catch. I had been using getGenericPaths("userId") but after internal discussion we don't presently offer value to anonymous users so I have changed this to getGenericPaths("userIdOnly") and no longer map through anonymousId. I've also updated the doc.

@manish339k manish339k removed the Stale label Jan 7, 2025
@manish339k
Copy link
Contributor

Add ACCOIL_ANALYTICS: true here

@manish339k manish339k changed the title Accoil analytics destination feat: accoil analytics destination Jan 7, 2025
@accoilmj
Copy link
Author

accoilmj commented Jan 8, 2025

@accoilmj accoilmj force-pushed the accoil-analytics-destination branch from 2c010f5 to ec8928e Compare January 8, 2025 01:48
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants