{"id":13612507,"url":"https://github.com/segment-boneyard/analytics-swift","last_synced_at":"2025-04-13T17:11:29.760Z","repository":{"id":32002862,"uuid":"35573795","full_name":"segment-boneyard/analytics-swift","owner":"segment-boneyard","description":"The hassle-free way to add analytics to your Swift app.","archived":false,"fork":false,"pushed_at":"2020-10-01T16:56:59.000Z","size":360,"stargazers_count":50,"open_issues_count":3,"forks_count":28,"subscribers_count":48,"default_branch":"master","last_synced_at":"2025-04-13T14:05:43.109Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":"https://segment.com/","language":"Swift","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/segment-boneyard.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE.md","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2015-05-13T20:56:56.000Z","updated_at":"2022-04-22T23:14:20.000Z","dependencies_parsed_at":"2022-08-26T10:10:28.274Z","dependency_job_id":null,"html_url":"https://github.com/segment-boneyard/analytics-swift","commit_stats":null,"previous_names":[],"tags_count":2,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/segment-boneyard%2Fanalytics-swift","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/segment-boneyard%2Fanalytics-swift/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/segment-boneyard%2Fanalytics-swift/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/segment-boneyard%2Fanalytics-swift/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/segment-boneyard","download_url":"https://codeload.github.com/segment-boneyard/analytics-swift/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":248750108,"owners_count":21155686,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2024-08-01T20:00:30.891Z","updated_at":"2025-04-13T17:11:29.738Z","avatar_url":"https://github.com/segment-boneyard.png","language":"Swift","funding_links":[],"categories":["HarmonyOS"],"sub_categories":["Windows Manager"],"readme":"# analytics-swift [![Carthage compatible](https://img.shields.io/badge/Carthage-compatible-4BC51D.svg?style=flat)](https://github.com/Carthage/Carthage)\n\nanalytics-swift is an Swift client for [Segment](https://segment.com).\n\nOur [analytics-ios](https://github.com/segmentio/analytics-ios) library is more full featured than it's Swift counterpart. You can use analytics-ios from a Swift project.\n\nThe analytics-ios library supports the following features that are *NOT* offered in the Swift library:\n\n* Queing events offline. Without this, the swift library will drop events once the user closes the app or when the user is offline.\n* Client side integrations. Without this, some integrations (such as Flurry, Localytics and others) cannot be used with the Swift library.\n\n\u003e **NOTE**: Official support from Segment for this plugin is **deprecated**. We recommend using our [`analytics-ios`](https://github.com/segmentio/analytics-ios) library.\n\n## 🏃💨 Quickstart for `analytics-ios`\n\u003cdiv align=\"center\"\u003e\n  \u003cimg src=\"https://user-images.githubusercontent.com/16131737/53451779-77f67000-39d4-11e9-8657-861c97c5de1b.png\"/\u003e\n  \u003cp\u003e\u003cb\u003e\u003ci\u003eYou can't fix what you can't measure\u003c/i\u003e\u003c/b\u003e\u003c/p\u003e\n\u003c/div\u003e\n\nAnalytics helps you measure your users, product, and business. It unlocks insights into your app's funnel, core business metrics, and whether you have product-market fit.\n\n### How to get started\n1. **Collect analytics data** from your app(s).\n    - The top 200 Segment companies collect data from 5+ source types (web, mobile, server, CRM, etc.).\n2. **Send the data to analytics tools** (for example, Google Analytics, Amplitude, Mixpanel).\n    - Over 250+ Segment companies send data to eight categories of destinations such as analytics tools, warehouses, email marketing and remarketing systems, session recording, and more.\n3. **Explore your data** by creating metrics (for example, new signups, retention cohorts, and revenue generation).\n    - The best Segment companies use retention cohorts to measure product market fit. Netflix has 70% paid retention after 12 months, 30% after 7 years.\n\n[Segment](https://segment.com?utm_source=github\u0026utm_medium=click\u0026utm_campaign=protos_swift) collects analytics data and allows you to send it to more than 250 apps (such as Google Analytics, Mixpanel, Optimizely, Facebook Ads, Slack, Sentry) just by flipping a switch. You only need one Segment code snippet, and you can turn integrations on and off at will, with no additional code. [Sign up with Segment today](https://app.segment.com/signup?utm_source=github\u0026utm_medium=click\u0026utm_campaign=protos_swift).\n\n### Why?\n1. **Power all your analytics apps with the same data**. Instead of writing code to integrate all of your tools individually, send data to Segment, once.\n\n2. **Install tracking for the last time**. We're the last integration you'll ever need to write. You only need to instrument Segment once. Reduce all of your tracking code and advertising tags into a single set of API calls.\n\n3. **Send data from anywhere**. Send Segment data from any device, and we'll transform and send it on to any tool.\n\n4. **Query your data in SQL**. Slice, dice, and analyze your data in detail with Segment SQL. We'll transform and load your customer behavioral data directly from your apps into Amazon Redshift, Google BigQuery, or Postgres. Save weeks of engineering time by not having to invent your own data warehouse and ETL pipeline.\n\n    For example, you can capture data on any app:\n    ```js\n    analytics.track('Order Completed', { price: 99.84 })\n    ```\n    Then, query the resulting data in SQL:\n    ```sql\n    select * from app.order_completed\n    order by price desc\n    ```\n---\nIn this tutorial you'll add your write key to the Swift demo app to start sending data from the app to Segment, and from there to any of our destinations, using our [analytics-ios library](https://segment.com/docs/sources/mobile/ios?utm_source=github\u0026utm_medium=click\u0026utm_campaign=protos_swift). Once your app is set up, you'll be able to turn on new destinations with the click of a button! Ready to try it for yourself? Scroll down to the \u003ca href=\"#demo\"\u003edemo section\u003c/a\u003e and run the app!\n\nStart sending data from your iOS source by interacting with the demo app:\n\n\u003cdiv align=\"center\"\u003e\n  \u003cimg src=\"https://user-images.githubusercontent.com/16131737/53607045-f0defe80-3b71-11e9-9e38-2b844fc3ec4b.gif\" height=\"700\"/\u003e\n\u003c/div\u003e\n\u003cbr/\u003e\n\nAnd view events occur live in your Segment Debugger:\n\n\u003cdiv align=\"center\"\u003e\n  \u003cimg src=\"https://user-images.githubusercontent.com/16131737/53607629-664bce80-3b74-11e9-9d6d-d4b3331e7bae.gif\"/\u003e\n\u003c/div\u003e\n\n## 🔌 Installing on Your App\nHow do you get this in your own Swift app? Follow the steps below.\n\n### 📦 Step 1: Install the SDK\nTo install Segment in your own app, follow the 3 steps below:\n1. The recommended way to install Analytics for iOS is via [Cocoapods](http://cocoapods.org/). Add the `Analytics` dependency to your `Podfile` to access the SDK:\n\t```Swift\n\tpod 'Analytics', :git =\u003e 'https://github.com/segmentio/analytics-ios.git', :branch =\u003e 'master'\n\t```\n\tIf you are using [Carthage](https://github.com/Carthage/Carthage), use this line in your  `Cartfile`:\n\t```Swift\n\tgithub \"segmentio/analytics-ios\" \"master\"\n\t```\n\n2. In `AppDelegate`, import the library:\n\t```Swift\n\timport Analytics\n\t```\n\n\tThen, modify your `application` method with the following snippet below:\n    ```Swift\n    func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -\u003e Bool {\n        let config = SEGAnalyticsConfiguration(writeKey: \"YOUR_WRITE_KEY\")\n        SEGAnalytics.setup(with: config)\n        return true\n    }\n    ```\n\n3. [Sign up with Segment](https://app.segment.com/signup?utm_source=github\u0026utm_medium=click\u0026utm_campaign=protos_swift) and locate your Segment project's **Write Key**. Replace `YOUR_WRITE_KEY` in the snippet above with your Segment project's write key.\u003cbr/\u003e\n    \u003e **Tip!** You can find your write key in your Segment project setup guide or settings.\n\nNow `SEGAnalytics.shared()` is loaded and available to use throughout your app!\n\n#### Logging\nTo see a trace of your data going through the SDK, you can enable debug logging with  `debug` property. Set the `debug` property to `true` on the `config` object in your `AppDelegate`:\n```Swift\nconfig.debug = true\n```\n#### Middleware\nA middleware is a simple function that is invoked by the Segment SDK and can be used to monitor, modify or reject events.\n\nSee the middlewares section in our [official documentation](https://segment.com/docs/sources/mobile/ios/#middlewares).\n\nIn the next sections you'll build out your implementation to track screen loads, to identify individual users of your app, and track the actions they take.\n\n### 📱 Step 2: Track Screen Views\nThe snippet from Step 1 loads `analytics-ios` into your app and is ready to track screen loads. The `screen` method lets you record screen views on your website, along with optional information about the screen being viewed. You can read more about how this works in the [screen reference](https://segment.com/docs/sources/mobile/ios/#screen?utm_source=github\u0026utm_medium=click\u0026utm_campaign=protos_swift).\n\n#### Automatic Screen Calls\nOur SDK can automatically instrument screen calls. It can detect when `ViewControllers` are loaded and uses the label of the view controller (or the class name if a label is not available) as the screen name. If present, it removes the string \"ViewController\" from the name.\n\nSet the `recordScreenViews` property to `true` on the `config` object in your `AppDelegate`:\n\n```Swift\nconfig.recordScreenViews = true\n```\n\n#### Manual Screen Calls\nIf your screens are separated into their own `UIViewController` classes, you can use the inherited `viewDidAppear` method to invoke `screen` calls. The example below shows one way you could do this.\n\n```Swift\nimport UIKit\nimport Analytics\n\nclass ViewController: UIViewController {\n    override func viewDidAppear(_ animated: Bool) {\n        super.viewDidAppear(animated)\n        SEGAnalytics.shared().screen(\"Home\")\n    }\n}\n```\n\n### 🔍 Step 3: Identify Users\nThe `identify` method is how you tell Segment who the current user is. It includes a unique User ID and any optional traits you can pass on about them. You can read more about this in the [identify reference](https://segment.com/docs/sources/mobile/ios/#identify?utm_source=github\u0026utm_medium=click\u0026utm_campaign=protos_swift).\n\n**Note:** You don't need to call `identify` for anonymous visitors to your site. Segment automatically assigns them an `anonymousId`, so just calling `screen` and `track` still works just fine without `identify`.\n\nHere's what a basic call to `identify` might look like:\n\n```Swift\nSEGAnalytics.shared().identify(\"f4ca124298\", properties: [\n    \"name\": \"Michael Bolton\",\n    \"email\": \"mbolton@initech.com\"\n])\n```\n\nThis call identifies Michael by his unique User ID and labels him with `name` and `email` traits.\n\nIn Swift, if you have a form where users sign up or log in, you can use an action method and bind a `UIButton` handler to call `identify`, as in the example below:\n\n```Swift\nimport UIKit\nimport Analytics\n\nclass SignUpViewController: UIViewController {\n\n    @IBOutlet fileprivate var usernameField: UITextField!\n    @IBOutlet fileprivate var emailField: UITextField!\n    @IBOutlet fileprivate var passwordField: UITextField!\n\n    override func viewDidLoad() {\n        super.viewDidLoad()\n        usernameField.text = \"\"\n        emailField.text = \"\"\n        passwordField.text = \"\"\n    }\n\n    @IBAction func signUp(_ sender: UIButton) {\n        // Handle sign up validation logic...\n      \n        // Add your own unique ID here or we will automatically assign an anonymousID\n        SEGAnalytics.shared().identify(traits: [\n            \"name\": usernameField.text,\n            \"email\": emailField.text\n        ])\n    }\n}\n```\n\n### ⏰ Step 4: Track Actions\nThe `track` method is how you tell Segment about which actions your users are performing on your site. Every action triggers what we call an \"event\", which can also have associated properties. It is important to figure out exactly what events you want to `track` instead of tracking anything and everything. A good way to do this is to build a [tracking plan](https://segment.com/docs/guides/sources/can-i-see-an-example-of-a-tracking-plan?utm_source=github\u0026utm_medium=click\u0026utm_campaign=protos_swift). You can read more about `track` in the [track reference](https://segment.com/docs/sources/mobile/ios/#track?utm_source=github\u0026utm_medium=click\u0026utm_campaign=protos_swift).\n\nHere's what a call to `track` might look like when a user bookmarks an article:\n\n```Swift\nSEGAnalytics.shared().track(\"Article Bookmarked\", properties: [\n    \"title\": \"Snow Fall\",\n    \"subtitle\": \"The Avalanche at Tunnel Creek\",\n    \"author\": \"John Branch\"\n])\n```\n\nThe snippet tells us that the user just triggered the **Article Bookmarked** event, and the article they bookmarked was the `Snow Fall` article authored by `John Branch`. Properties can be anything you want to associate to an event when it is tracked.\n\n#### Track Calls with Event Handlers\nIn Swift, you can use an action method to call the `track` events. In the example below, we bind a `UIButton` handler to make a `track` call to log a `User Signup`.\n\n```Swift\n@IBAction func handleSignupEvent(_ sender: UIButton) {\n    SEGAnalytics.shared().track(\"User Signup\")\n}\n```\n\n### 🎓 Advanced\nOnce you've mastered the basics, here are some advanced use cases you can apply with Segment.\n\n#### Eureka Form\nIf you're using the [Eureka library](https://github.com/xmartlabs/Eureka) to build your forms, you can use the `onChange` callback to send `track` calls for when a user interacts with part of the form.\n\n```Swift\nimport Eureka\nimport Analytics\n\nclass MyFormViewController: FormViewController {\n    override func viewDidLoad() {\n        super.viewDidLoad()\n        form +++ Section(\"Section1\")\n            \u003c\u003c\u003c TextRow(){ row in\n                row.title = \"Text Row\"\n                row.placeholder = \"Enter text here\"\n            }.onChange { row in\n                SEGAnalytics.shared().track(\"Updated Text Row With \\(row.value)\")\n            }\n\n            \u003c\u003c\u003c PhoneRow(){\n                $0.title = \"Phone Row\"\n                $0.placeholder = \"And numbers here\"\n            }.onChange {\n                SEGAnalytics.shared().track(\"Updated Phone Row With \\($0.value)\")\n            }\n\n        +++ Section(\"Section2\")\n            \u003c\u003c\u003c DateRow(){\n                $0.title = \"Date Row\"\n                $0.value = Date(timeIntervalSinceReferenceDate: 0)\n            }.onChange {\n                SEGAnalytics.shared().track(\"Updated Date Row With \\($0.value)\")\n            }\n    }\n}\n```\n\n### ⌛ Batching\nYou may see a delay in some of your events because of the behavior of our SDK. Our SDK queues API calls so that we:\n+ **Reduce Network Usage** — Each batch is gzip compressed, decreasing the amount of bytes on the wire by 10x-20x.\n+ **Save Battery** — Because of data batching and compression, Segment's SDKs reduce energy overhead by 2-3x which means longer battery life for your app's users.\n\nIt is **not recommended**, but you can immediately send your queued events by calling `flush` after your original call:\n```Swift\nSEGAnalytics.shared().screen(\"About\")\nSEGAnalytics.shared().flush()\n```\nOr, set your batch size to 1 by modifying the `flushAt` property  on the `config` object in your `AppDelegate`:\n```Swift\nconfig.flushAt = 1;\n```\n\nYou can read more about the lifecycle of a mobile API call by reading our [blog post](https://segment.com/blog/lifecycle-of-a-mobile-message/).\n\n### 🤔 What's next?\nOnce you've added a few track calls, **you're done**! You've successfully installed `analytics-ios` tracking with your Swift app. Now you're ready to see your data in the Segment dashboard, and turn on any destination tools. 🎉\n\nYou may wondering what you can be doing with all the raw data you are sending to Segment from your Swift app. With our [warehouses product](https://segment.com/product/warehouses?utm_source=github\u0026utm_medium=click\u0026utm_campaign=protos_swift), your analysts and data engineers can shift focus from data normalization and pipeline maintenance to providing insights for business teams. Having the ability to query data directly in SQL and layer on visualization tools can take your product to the next level.\n\n### 💾 Warehouses\nA warehouse is a special subset of destinations where we load data in bulk at a regular intervals, inserting and updating events and objects while automatically adjusting their schema to fit the data you've sent to Segment. We do the heavy lifting of capturing, schematizing, and loading your user data into your data warehouse of choice.\n\nExamples of data warehouses include Amazon Redshift, Google BigQuery, MySQL, and Postgres.\n\n\u003cdiv align=\"center\"\u003e\n  \u003cimg src=\"https://user-images.githubusercontent.com/16131737/53608172-9bf1b700-3b76-11e9-9c20-b9790f7ea33e.gif\"/\u003e\n\u003c/div\u003e\n\n### 📺 \u003cspan name=\"demo\"\u003eDemo\u003c/span\u003e\n#### Requirements:\n+ Swift 4.2+\n+ Xcode 10.1+\n+ `analytics-ios` 3.6.10\n\nTo run the demo app, follow the instructions below:\n1. [Sign up with Segment](https://app.segment.com/signup?utm_source=github\u0026utm_medium=click\u0026utm_campaign=protos_swift) and edit the snippet in [AppDelegate](https://github.com/segmentio/analytics-ios/tree/master/Examples/AnalyticsSwiftExample/AnalyticsSwiftExample/AppDelegate.swift#L18) to replace `YOUR_WRITE_KEY` with your Segment **Write Key**.\n    \u003e **Tip!** You can find your key in your project setup guide or settings in the Segment.\n\n    ```Swift\n    func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -\u003e Bool {\n        let config = SEGAnalyticsConfiguration(writeKey: \"YOUR_WRITE_KEY\")\n        SEGAnalytics.setup(with: config)\n        return true\n    }\n    ```\n\n4. From the command line, use `pod install` to install the dependencies:\n    ```bash\n    pod install\n    ```\n\t  Then, open the project in `Xcode` and press `⌘R` to run the app.\n5. Go to the Segment site, and in the Debugger look at the live events being triggered in your app. You should see the following:\n    - Screen event: `Home` - When someone views the `home` screen.\n    - Screen event: `About` - When someone views the `about` screen.\n    - Track event: `Learn About Segment Clicked` - When someone clicks the \"Learn About Segment\" link.\n\nCongrats! You're seeing live data from your demo Swift app in Segment! 🎉\n\n### 🚀 Startup Program\n\u003cdiv align=\"center\"\u003e\n  \u003ca href=\"https://segment.com/startups\"\u003e\u003cimg src=\"https://user-images.githubusercontent.com/16131737/53128952-08d3d400-351b-11e9-9730-7da35adda781.png\" /\u003e\u003c/a\u003e\n\u003c/div\u003e\nIf you are part of a new startup  (\u0026lt;$5M raised, \u0026lt;2 years since founding), we just launched a new startup program for you. You can get a Segment Team plan  (up to \u003cb\u003e$25,000 value\u003c/b\u003e in Segment credits) for free up to 2 years — \u003ca href=\"https://segment.com/startups/\"\u003eapply here\u003c/a\u003e!\n\n### 📝 Docs \u0026 Feedback\nCheck out our full [analytics-ios reference](https://segment.com/docs/sources/mobile/ios?utm_source=github\u0026utm_medium=click\u0026utm_campaign=protos_swift) to see what else is possible, or read about the [Tracking API methods](https://segment.com/docs/sources/server/http?utm_source=github\u0026utm_medium=click\u0026utm_campaign=protos_swift) to get a sense for the bigger picture. If you have any questions, or see anywhere we can improve our documentation, [let us know](https://segment.com/contact?utm_source=github\u0026utm_medium=click\u0026utm_campaign=protos_swift)!\n\n## Installing the Library\n\n#### CocoaPods\n```\nuse_frameworks!\n\npod 'AnalyticsSwift', '~\u003e 0.2.0'\n```\n\n#### Manual\n1. Download the [latest binary](https://github.com/segmentio/analytics-swift/releases) of the library.\n2. Drag the `AnalyticsSwift.framework` file [into](https://cloudup.com/cBXYVa2ZmOL) your project.\n3. Under 'Build Phases', click the ['New Copy Files Phase'](https://cloudup.com/c7pDwmlNnhq) button.\n4. In the 'Copy Files' target, select 'Frameworks' as the destination and [drag the `Analytics.framework`](https://cloudup.com/cliU4MKF69U) file from the binary we added to the project in step 2.\n\n## Usage\n* Add the `AnalyticsSwift` library to your project.\n\n* Add the correct imports `import AnalyticsSwift`\n\n* Create an instance of the analytics client with your project write key:\n\n`var analytics = Analytics.create(YOUR_SEGMENT_WRITE_KEY_HERE)`\n\n* Create an instance of a message (either [`identify`](https://segment.com/docs/libraries/http/#identify), [`group`](https://segment.com/docs/libraries/http/#group), [`track`](https://segment.com/docs/libraries/http/#track), [`screen`](https://segment.com/docs/libraries/http/#screen), [`alias`](https://segment.com/docs/libraries/http/#alias)). Note that either `userId` or `anonymousId` is always required.\n\n`var message = TrackMessageBuilder(event: \"Button A\").userId(\"prateek\")`\n\n* Enqueue the message.\n\n`analytics.enqueue(message)`\n\n* Wait for the message to be uploaded or trigger a flush manually.\n\n`analytics.flush()`\n\n## Examples\n\nYou can see basic examples of the library in action [here](https://github.com/segmentio/analytics-swift-example).\n\n\n## License\n\n```\nWWWWWW||WWWWWW\n W W W||W W W\n      ||\n    ( OO )__________\n     /  |           \\\n    /o o|    MIT     \\\n    \\___/||_||__||_|| *\n         || ||  || ||\n        _||_|| _||_||\n       (__|__|(__|__|\n\n\n(The MIT License)\n\nCopyright (c) 2013 Segment Inc. \u003cfriends@segment.com\u003e\n\nPermission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the 'Software'), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n```\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsegment-boneyard%2Fanalytics-swift","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fsegment-boneyard%2Fanalytics-swift","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsegment-boneyard%2Fanalytics-swift/lists"}