{"id":20268599,"url":"https://github.com/agoraio/signaling-sdk-samples-ios","last_synced_at":"2025-07-07T18:32:47.624Z","repository":{"id":207918637,"uuid":"678832545","full_name":"AgoraIO/signaling-sdk-samples-ios","owner":"AgoraIO","description":null,"archived":false,"fork":false,"pushed_at":"2024-07-10T07:18:31.000Z","size":790,"stargazers_count":0,"open_issues_count":1,"forks_count":1,"subscribers_count":5,"default_branch":"main","last_synced_at":"2025-03-11T00:00:07.226Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"Swift","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/AgoraIO.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2023-08-15T13:40:53.000Z","updated_at":"2024-07-10T07:18:34.000Z","dependencies_parsed_at":"2024-11-14T12:19:39.614Z","dependency_job_id":"7689ac96-192d-4f96-9765-76c1ff726265","html_url":"https://github.com/AgoraIO/signaling-sdk-samples-ios","commit_stats":null,"previous_names":["agoraio/signaling-sdk-samples-ios"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/AgoraIO/signaling-sdk-samples-ios","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/AgoraIO%2Fsignaling-sdk-samples-ios","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/AgoraIO%2Fsignaling-sdk-samples-ios/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/AgoraIO%2Fsignaling-sdk-samples-ios/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/AgoraIO%2Fsignaling-sdk-samples-ios/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/AgoraIO","download_url":"https://codeload.github.com/AgoraIO/signaling-sdk-samples-ios/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/AgoraIO%2Fsignaling-sdk-samples-ios/sbom","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":264130498,"owners_count":23562038,"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-11-14T12:19:01.891Z","updated_at":"2025-07-07T18:32:47.606Z","avatar_url":"https://github.com/AgoraIO.png","language":"Swift","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Signaling SDK for iOS/macOS reference app\n\nThis app demonstrates using the [Agora's Signaling SDK](https://docs-beta.agora.io/en/signaling/get-started/get-started-sdk?platform=ios) for real-time communication in a SwiftUI app.\n\nThe example app is a documentation reference for iOS and macOS, designed to enhance your productivity and understanding. It's built to be flexible, easily extensible, and beginner-friendly.\n\n\u003e **Note:** :information_source: Please note that the code examples provided in this repository are for demonstration purposes only and are not officially supported by Agora. They may not reflect the latest best practices or updates in Agora's SDK. For the latest updates, please refer to [Agora's Official Documentation](https://docs.agora.io/en/signaling/overview/product-overview).\n\nUse these examples as a reference and modify them to suit your specific needs.\n\n- [Samples](#samples)\n- [Prerequisites](#prerequisites)\n- [Run this project](#run-this-project)\n- [Screenshots](#screenshots)\n- [Contact](#contact)\n\n## Samples\n\nYou'll find numerous examples illustrating the functionality and features of this reference app in the root directory. Each example is self-contained in its own directory, providing an easy way to understand how to use the app. For more information about each example, see the README file within its directory.\n\n### Get Started\n- [SDK quickstart](./get-started-sdk/)\n- [Secure authentication with tokens](./authentication-workflow/)\n\n### Core Functionality\n\n- [Stream channels](./stream-channels/)\n- [Presence](./presence/)\n- [Store channel and user data](./storage/)\n- [Connect through restricted networks with Cloud Proxy](./cloud-proxy/)\n- [Data encryption](./data-encryption/)\n\n### Integrate Features\n\n- [Geofencing](./geofencing/)\n\n## Prerequisites\n\nBefore getting started with this example app, please ensure you have the following software installed on your machine:\n\n- Xcode 14.0 or later.\n- Swift 5.8 or later.\n\n## Run this project\n\n1. **Clone the repository**\n\n    To clone the repository to your local machine, open Terminal and navigate to the directory where you want to clone the repository. Then, use the following command:\n    \n    ```sh\n    git clone https://github.com/AgoraIO/signaling-sdk-samples-ios.git\n    ```\n\n2. **Open the project**\n\n   Navigate to [Example-App](Example-App), and open [Example-App.xcodeproj](Example-App/Example-App.xcodeproj).\n   \n   \u003e All dependencies are installed with Swift Package Manager, so will be fetched automatically by Xcode.\n\n3. **Update Signing**\n\n   As with any Xcode project, head to the target, \"Signing \u0026 Capabilities\", and add your team, and modify the bundle identifier to make it unique.\n\n4.  **Modify the project configuration**\n\n   The app loads connection parameters from the [`config.json`](./agora-manager/config.json) file. Ensure that the \n   file is populated with the required parameter values before running the application.\n\n    - `uid`: The user ID associated with the application, or identifierForVendor to take the device ID.\n    - `appId`: (Required) The unique ID for the application obtained from [Agora Console](https://console.agora.io). \n    - `channelName`: The default name of the channel to join.\n    - `token`: A token generated for `uid`. You generate a temporary token using the [Agora token builder](https://agora-token-generator-demo.vercel.app/).\n    - `tokenUrl`: The URL for the token generator. See [Secure authentication with tokens](./authentication-workflow) for information on how to set up a token server.\n\n   If a valid `tokenUrl` is provided, all samples use the token server to obtain a token except the **SDK quickstart** project that uses the `token`. If a `tokenUrl` is not specified, all samples except **Secure authentication with tokens** use the `token` from `config.json`.\n\n5. **Build and run the project**\n\n   To build and run the project, use the build button (Cmd+R) in Xcode. Select your preferred device/simulator as the scheme.\n\n## Screenshots\n\n| Default Chat View |\n|:-:|\n| ![Default Chat View](Resources/media/rtm-ios-get-started.png) |\n\n## Contact\n\nIf you have any questions, issues, or suggestions, please file an issue in our [GitHub Issue Tracker](https://github.com/AgoraIO/signaling-sdk-samples-ios/issues).\n\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fagoraio%2Fsignaling-sdk-samples-ios","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fagoraio%2Fsignaling-sdk-samples-ios","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fagoraio%2Fsignaling-sdk-samples-ios/lists"}