Skip to content

rudderlabs/rudder-sdk-swift

Repository files navigation

RudderStack
The Customer Data Platform for Developers

Website · Documentation · Community Slack


RudderStack Swift SDK

The Swift SDK enables you to track customer event data from your iOS, macOS, tvOS, and watchOS applications and send it to your configured destinations via RudderStack.

Table of Contents


Installing the Swift SDK

Swift Package Manager

Add the SDK to your Swift project using Swift Package Manager:

  1. In Xcode, go to File > Add Package Dependencies

Add Package Dependencies dialog in Xcode

  1. Enter the package repository URL: https://github.com/rudderlabs/rudder-sdk-swift in the search bar.
  2. Select the version you want to use

Select package version in Xcode

  1. Select the target to which you want to add the package.
  2. Finally, click on Add Package.

Add Package button in Xcode

Alternatively, add it to your Package.swift file:

// swift-tools-version:5.9
// The swift-tools-version declares the minimum version of Swift required to build this package.

import PackageDescription

let package = Package(
    name: "RudderStack",
    products: [
        // Products define the executables and libraries a package produces, and make them visible to other packages.
        .library(
            name: "RudderStack",
            targets: ["RudderStack"]),
    ],
    dependencies: [
        // Dependencies declare other packages that this package depends on.
        .package(url: "https://github.com/rudderlabs/rudder-sdk-swift.git", .upToNextMajor(from: "<latest_version>"))
    ],
    targets: [
        // Targets are the basic building blocks of a package. A target can define a module or a test suite.
        // Targets can depend on other targets in this package, and on products in packages this package depends on.
        .target(
            name: "RudderStack",
            dependencies: [
                .product(name: "RudderStackAnalytics", package: "rudder-sdk-swift")
            ]),
        .testTarget(
            name: "RudderStackTests",
            dependencies: ["RudderStack"]),
    ]
)

Platform Support

The SDK supports the following platforms:

  • iOS 15.0+
  • macOS 12.0+
  • tvOS 15.0+
  • watchOS 8.0+

Initializing the SDK

To initialize the RudderStack Swift SDK, add the Analytics initialization snippet to your application's entry point:

import RudderStackAnalytics

class AppDelegate: UIResponder, UIApplicationDelegate {
    
    var analytics: Analytics?
    
    func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
        
        // Initialize the RudderStack Analytics SDK
        let config = Configuration(
            writeKey: "<WRITE_KEY>",
            dataPlaneUrl: "<DATA_PLANE_URL>"
        )
        self.analytics = Analytics(configuration: config)
        
        return true
    }
}

Replace:

  • <WRITE_KEY>: Your project's write key from the RudderStack dashboard.
  • <DATA_PLANE_URL>: The URL of your RudderStack data plane.

Identifying users

The identify API lets you recognize a user and associate them with their traits:

analytics?.identify(
    userId: "1hKOmRA4el9Zt1WSfVJIVo4GRlm",
    traits: [
        "name": "Alex Keener",
        "email": "[email protected]"
    ]
)

Tracking user actions

The track API lets you capture user events:

analytics?.track(
    name: "Order Completed",
    properties: [
        "revenue": 30.0,
        "currency": "USD"
        ]
)

Integrations

RudderStack Swift SDK supports various third-party integrations that allow you to send your event data to external analytics and marketing platforms. These integrations are implemented as separate modules that you can include in your project as needed.

Available Integrations

The following integrations are currently available:

  • Adjust - Send your event data to Adjust for product analytics
  • AppsFlyer - Send your event data to AppsFlyer for mobile attribution and analytics
  • Braze - Send your event data to Braze for customer engagement
  • Firebase - Send your event data to Google Firebase Analytics
  • Facebook - Send your event data to Facebook for analytics and advertising

Using Integrations

To use an integration, follow these steps:

  1. Add the integration dependency to your project using Swift Package Manager
  2. Initialize the RudderStack SDK as usual
  3. Add the integration to your Analytics instance

Example with multiple integrations:

import RudderStackAnalytics
import RudderIntegrationAdjust
import RudderIntegrationFirebase

class AppDelegate: UIResponder, UIApplicationDelegate {
    
    var analytics: Analytics?
    
    func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
        
        // Initialize the RudderStack Analytics SDK
        let config = Configuration(
            writeKey: "<WRITE_KEY>",
            dataPlaneUrl: "<DATA_PLANE_URL>"
        )
        self.analytics = Analytics(configuration: config)
        
        // Add integrations
        analytics?.add(plugin: AdjustIntegration())
        analytics?.add(plugin: FirebaseIntegration())
        // Add more integrations as needed
        
        return true
    }
}

Contact us

For more information:

Follow Us

About

Swift SDK for iOS, macOS, watchOS, tvOS for RudderStack - the Customer Data Platform for Developers.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 7

Languages