Skip to content

daily-demos/daily-ios-demo

Folders and files

NameName
Last commit message
Last commit date
Apr 26, 2022
Feb 28, 2025
Nov 4, 2024
Nov 20, 2023
Apr 26, 2022
Apr 26, 2022
Apr 26, 2022
Apr 26, 2022
May 16, 2023

A video chat app using the Daily Client SDK for iOS

This demo is meant to showcase a basic video chat app that uses Daily's native iOS SDK mobile library.

Prerequisites

How the demo works

In the demo app, a user must enter a URL for a Daily Room, then press Join. The app will find the meeting room and join the call. The app initializes a Call Client, which keeps track of important information about the meeting, like other participants (including their audio and video tracks) and the things they do on the call (e.g. muting their mic or leaving), and provides methods for interacting with the meeting. The app leverages this object to update its state accordingly, and to carry out user actions like muting or changing track-publishing statuses. When the user leaves the meeting room, the Call Client remains, but their call has ended. The Call Client is destroyed when the application exits.

When testing or running this demo, you'll likely use a room you've manually created for calls. A production application will likely need to use the Daily REST API to create rooms on the fly for your users, which necessitates the use of a sensitive Daily API key. You likely don't want to embed this key in a production app. We recommend running a web server and keeping sensitive things like API keys there instead.

This project is designed to work with rooms that have privacy set to public or private. When joining a private room, you must provide a valid token to access the room. At the moment, knocking for access is not supported, meaning that a token is always required when joining a private room.

Running locally

  1. Clone this repository locally, i.e.: git clone git@github.com:daily-demos/daily-ios-demo.git
  2. Open the DailyDemo.xcodeproj in Xcode.
  3. Tell Xcode to update its Package Dependencies by clicking File -> Packages -> Update to Latest Package Versions.
  4. Build the project for either a simulator (which will not have webcam access) or a device.
  5. Run the project on a simulator or on your device.
  6. Connect to the room URL you are testing, and to see it work, connect again either in another simulator, on another device, or directly using a web browser. Careful of mic feedback! You might want to mute one or both side's audio if they're near each other.

Contributing and feedback

Let us know how experimenting with this demo goes! Feel free to open an Issue, or reach us any time at help@daily.co.