Skip to content

Commit

Permalink
Updated readme.
Browse files Browse the repository at this point in the history
  • Loading branch information
bsneed committed Nov 2, 2023
1 parent bf8bc30 commit af9346f
Show file tree
Hide file tree
Showing 3 changed files with 177 additions and 20 deletions.
197 changes: 177 additions & 20 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,8 +1,133 @@
# Analytics-Swift-Consent
# Segment Consent Management

Add Segment driven consent management support for your application via this plugin for [Analytics-Swift](https://github.com/segmentio/analytics-swift)

## Adding the dependency
This plugin provides the framework to integration Consent Management Platform (CMP) SDKs like OneTrust to supply consent status and potential block events going to device mode destinations.

Read more about Segment's Consent Management solutions [here](https://segment.com/docs/privacy/configure-consent-management/), as well as enabling it for your workspace.

## Background

Consent Management is the management of a user’s consent preferences related to privacy. You might be familiar with the Privacy Pop-ups that have become mandated recently that ask the user if he or she consents to the use of certain category of cookies:

![Sample CMP UI](imgs/cmp-sample.png?raw=true "Sample CMP UI")


The Privacy pop-up asks the user if he or she will consent to the use of cookies and allows the user to customize their consent by turning on/off different categories of cookies.

After the user selects “Allow All” or “Save Preferences” a callback is fired and the owner of the website is notified as to the consent preferences of a given user. The website owner must then store that consent preference and abide by it. Any rejected cookies must not be set or read to avoid large fines that can be handed down by government authorities.

Additionally, besides the initial pop-up the app owner must give users a way to later change any preferences they originally selected. This is usually accomplished by providing a button to display the customization screen.


## Segment managed CMP

Segment provides a framework for users to integrate any CMP they choose and use the Segment web app to map consent categories to device mode destinations. This information is sent down the analytics-kotlin SDK and stored for later lookup.

Every event that flows through the library will be stamped with the current status according to whatever configured CMP is used. Event stamping is handled by the ConsentManagementPlugin.

Using consent status stamped on the events and the mappings sent down from the Segment web app each event is evaluated and action is taken. Currently the supported actions are:

- Blocking - This action is implemented by the ConsentBlockingPlugin

## Event Stamping

Event stamping is the process of adding the consent status information to an existing event. The information is added to the context object of every event. Below is a before and after example:

Before

```json
{
"anonymousId": "23adfd82-aa0f-45a7-a756-24f2a7a4c895",
"type": "track",
"event": "MyEvent",
"userId": "u123",
"timestamp": "2023-01-01T00:00:00.000Z",
"context": {
"traits": {
"email": "[email protected]",
"phone": "555-555-5555"
},
"device": {
"advertisingId": "7A3CBBA0-BDF5-11E4-8DFC-AA02A5B093DB"
}
}
}
```
After

```json
{
"anonymousId": "23adfd82-aa0f-45a7-a756-24f2a7a4c895",
"type": "track",
"event": "MyEvent",
"userId": "u123",
"timestamp": "2023-01-01T00:00:00.000Z",
"context": {
"traits": {
"email": "[email protected]",
"phone": "555-555-5555"
},
"device": {
"advertisingId": "7A3CBBA0-BDF5-11E4-8DFC-AA02A5B093DB"
},
"consent": {
"categoryPreferences": {
"Advertising": true,
"Analytics": false,
"Functional": true,
"DataSharing": false
}
}
}
}
```

## Segment Consent Preference Event

When notified by the CMP SDK that consent has changed, a track event with name “Segment Consent Preference” will be emitted. Below is example of what that event will look like:

```json
{
"anonymousId": "23adfd82-aa0f-45a7-a756-24f2a7a4c895",
"type": "track",
"event": "Segment Consent Preference",
"userId": "u123",
"timestamp": "2023-01-01T00:00:00.000Z",
"context": {
"device": {
"advertisingId": "7A3CBEA0-BDF5-11E4-8DFC-AA07A5B093DB"
},
"consent": {
"categoryPreferences": {
"Advertising": true,
"Analytics": false,
"Functional": true,
"DataSharing": false
}
}
}
}
```

## Event Flow


![Shows how an event is stamped and later checked for consent](imgs/main-flow-diagram.png?raw=true "Event Flow Diagram")

1. An event is dropped onto the timeline by some tracking call.
2. The ConsentManagementPlugin consumes the event, stamps it, and returns it.
3. The event is now stamped with consent information from this point forward.
4. The event is copied. The copy is consumed by a Destination Plugin and continues down its internal timeline. The original event is returned and continues down the main timeline.
a. The stamped event is now on the timeline of the destination plugin.
b. The event reaches the ConsentBlockingPlugin which makes a decision as to whether or not to let the event continue down the timeline.
c. If the event has met the consent requirements it continues down the timeline.
5. The event continues down the timeline.




## Getting Started

### via Xcode
In the Xcode `File` menu, click `Add Packages`. You'll see a dialog where you can search for Swift packages. In the search field, enter the URL to this repo.
Expand All @@ -23,42 +148,74 @@ Open your Package.swift file and add the following do your the `dependencies` se
),
```

Next pick from one of the prebuilt integration:

## Using the Plugin in your App
- OneTrust: https://github.com/segment-integrations/analytics-swift-consent-onetrust

Open the file where you setup and configure the Analytics-Swift library. Add this plugin to the list of imports.
Or build your own integration (see below)

```
import Segment
import SegmentConsent // <-- Add this line
```

Just under your Analytics-Swift library setup, call `analytics.add(plugin: ...)` to add an instance of the plugin to the Analytics timeline.
Next you'll need to write some setup/init code where you have your
Analytics setup:

```
```swift
let analytics = Analytics(configuration: Configuration(writeKey: "<YOUR WRITE KEY>")
.flushAt(3)
.trackApplicationLifecycleEvents(true))

let consentManager = ConsentManager(provider: MyConsentProvider())
analytics.add(plugin: consentManager)
// add any device mode destinations you might have ...
analytics.add(plugin: FirebaseDestination())
analytics.add(plugin: TaplyticsDestination())

// Note: Different consent management providers may require consentManager.start() be called differently.
// Tell the consent manager to start processing events. It will queue events until start() is called.
consentManager.start()
```

Your events will now begin to have the consent management preferences applied.
The Consent Manager plugin will automatically add a ConsentBlockingPlugin to any device mode destinations, so there's no extra steps for you to do in your code. Blocking for cloud mode destinations will be handled server-side at Segment.

## Building your own integration

In order to integrate a new CMP all you have down is make your own ConsentCategoryProvider object.

### Consent Category Provider

You'll need to create a `ConsentCategoryProvider` that will provide a mapping of consent category to whether or not a given category has been consented by the user. It must also provide a way to inform the `ConsentManager` of any changes that happen during runtime.

Example:
```swift
class MyConsentProvider: ConsentCategoryProvider {
// this will be set later by the ConsentManager.
var changeCallback: ConsentChangeCallback? = nil
// this is the imaginary Consent SDK you supplied/wrote.
let consentSDK: MyConsentSDK

var categories: [String : Bool] {
// Returns a simple dictionary of categories and their
// enabled/disabled status.
//
// ie: ["Analytics": true, "Advertising": false, "Performance": true]
return consentSDK.categoriesAndStatus()
}

init(consentSDK: MyConsentSDK) {
self.consentSDK = consentSDK
self.consentSDK.changeListener = consentChanged
}

func consentChanged() {
guard let changeCallback else { return }
// this will tell the ConsentManager that consent has changed, it
// will check the `categories` above again and then send
// a "Segment Consent Preference" track event with the updates.
changeCallback()
}
}

```

## Support

Please use Github issues, Pull Requests, or feel free to reach out to our [support team](https://segment.com/help/).

## Integrating with Segment

Interested in integrating your service with us? Check out our [Partners page](https://segment.com/partners/) for more details.
That's all! Enjoy. Feel free to reach out via GitHub Issues, or to Segment support for any additional assitance or questions.

## License
```
Expand Down
Binary file added imgs/cmp-sample.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added imgs/main-flow-diagram.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.

0 comments on commit af9346f

Please sign in to comment.