Интеграция Daily.co для видеозвонков на сайте

Наша компания занимается разработкой, поддержкой и обслуживанием сайтов любой сложности. От простых одностраничных сайтов до масштабных кластерных систем построенных на микро сервисах. Опыт разработчиков подтвержден сертификатами от вендоров.

Разработка и обслуживание любых видов сайтов:

Информационные сайты или веб-приложения
Сайты визитки, landing page, корпоративные сайты, онлайн каталоги, квиз, промо-сайты, блоги, новостные ресурсы, информационные порталы, форумы, агрегаторы
Сайты или веб-приложения электронной коммерции
Интернет-магазины, B2B-порталы, маркетплейсы, онлайн-обменники, кэшбэк-сайты, биржи, дропшиппинг-платформы, парсеры товаров
Веб-приложения для управления бизнес-процессами
CRM-системы, ERP-системы, корпоративные порталы, системы управления производством, парсеры информации
Сайты или веб-приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, конструкторы сайтов, порталы предоставления электронных услуг, видеохостинги, тематические порталы

Это лишь некоторые из технических типов сайтов, с которыми мы работаем, и каждый из них может иметь свои специфические особенности и функциональность, а также быть адаптированным под конкретные потребности и цели клиента

Предлагаемые услуги
Показано 1 из 1 услугВсе 2065 услуг
Интеграция Daily.co для видеозвонков на сайте
Средняя
~3-5 рабочих дней
Часто задаваемые вопросы

Наши компетенции:

Этапы разработки

Последние работы

  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1262
  • image_web-applications_feedme_466_0.webp
    Разработка веб-приложения для компании FEEDME
    1171
  • image_websites_belfingroup_462_0.webp
    Разработка веб-сайта для компании БЕЛФИНГРУПП
    874
  • image_ecommerce_furnoro_435_0.webp
    Разработка интернет магазина для компании FURNORO
    1094
  • image_crm_enviok_479_0.webp
    Разработка веб-приложения для компании Enviok
    831
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Разработка веб-сайта для компании ФИКСПЕР
    851

Интеграция Daily.co для видеозвонков на сайте

Daily.co предоставляет WebRTC-инфраструктуру с простым JavaScript SDK. Создаёте комнату через REST API, передаёте URL пользователю — он открывает видеозвонок прямо в браузере без установки приложения. Подходит для видеоконсультаций, support-чатов, обучения.

Создание комнаты через REST API

const DAILY_API_KEY = process.env.DAILY_API_KEY;

async function createRoom(options: {
  name?: string;
  expiresInMinutes?: number;
  maxParticipants?: number;
}): Promise<{ url: string; name: string }> {
  const response = await fetch('https://api.daily.co/v1/rooms', {
    method: 'POST',
    headers: {
      'Authorization': `Bearer ${DAILY_API_KEY}`,
      'Content-Type': 'application/json',
    },
    body: JSON.stringify({
      name: options.name ?? `room-${Date.now()}`,
      properties: {
        exp: Math.floor(Date.now() / 1000) + (options.expiresInMinutes ?? 60) * 60,
        max_participants: options.maxParticipants ?? 10,
        enable_screenshare: true,
        enable_chat: true,
        enable_recording: false,
        start_video_off: false,
        start_audio_off: false,
      },
    }),
  });

  const room = await response.json();
  return { url: room.url, name: room.name };
}

// API для создания сессии
app.post('/api/video/room', authenticate, async (req, res) => {
  const { consultationId } = req.body;
  const room = await createRoom({
    name: `consultation-${consultationId}`,
    expiresInMinutes: 90,
    maxParticipants: 2,
  });

  await db.consultations.update(consultationId, { roomUrl: room.url });
  res.json({ url: room.url });
});

Токен участника

Для приватных комнат нужен meeting token — иначе в комнату попадёт любой с URL:

async function createMeetingToken(roomName: string, participantName: string, isOwner = false) {
  const response = await fetch('https://api.daily.co/v1/meeting-tokens', {
    method: 'POST',
    headers: {
      'Authorization': `Bearer ${DAILY_API_KEY}`,
      'Content-Type': 'application/json',
    },
    body: JSON.stringify({
      properties: {
        room_name: roomName,
        user_name: participantName,
        is_owner: isOwner,  // владелец может удалять других участников
        exp: Math.floor(Date.now() / 1000) + 90 * 60,
        enable_recording: isOwner,
      },
    }),
  });

  const { token } = await response.json();
  return token;
}

React компонент с Daily JS SDK

npm install @daily-co/daily-js
import DailyIframe from '@daily-co/daily-js';
import { useEffect, useRef, useState } from 'react';

interface VideoCallProps {
  roomUrl: string;
  token: string;
  userName: string;
  onLeave?: () => void;
}

function VideoCall({ roomUrl, token, userName, onLeave }: VideoCallProps) {
  const callRef = useRef<ReturnType<typeof DailyIframe.createFrame> | null>(null);
  const containerRef = useRef<HTMLDivElement>(null);
  const [status, setStatus] = useState<'idle' | 'joining' | 'joined' | 'left'>('idle');

  useEffect(() => {
    if (!containerRef.current) return;

    const call = DailyIframe.createFrame(containerRef.current, {
      showLeaveButton: true,
      showFullscreenButton: true,
      iframeStyle: { width: '100%', height: '100%', border: 'none', borderRadius: '12px' },
    });

    callRef.current = call;

    call.on('joining-meeting', () => setStatus('joining'));
    call.on('joined-meeting', () => setStatus('joined'));
    call.on('left-meeting', () => {
      setStatus('left');
      onLeave?.();
    });
    call.on('error', (err) => console.error('Daily error:', err));

    call.join({ url: roomUrl, token, userName });

    return () => {
      call.destroy();
    };
  }, [roomUrl, token]);

  return (
    <div className="relative" style={{ height: 600 }}>
      {status === 'joining' && (
        <div className="absolute inset-0 flex items-center justify-center bg-gray-900 rounded-xl z-10">
          <p className="text-white">Подключение...</p>
        </div>
      )}
      {status === 'left' && (
        <div className="absolute inset-0 flex items-center justify-center bg-gray-900 rounded-xl z-10">
          <p className="text-white text-lg">Звонок завершён</p>
        </div>
      )}
      <div ref={containerRef} className="w-full h-full" />
    </div>
  );
}

Webhooks для событий

Daily.co отправляет события на ваш сервер:

app.post('/api/webhooks/daily', async (req, res) => {
  const { event_type, payload } = req.body;

  switch (event_type) {
    case 'meeting.started':
      await db.videoSessions.markStarted(payload.room.name);
      break;
    case 'meeting.ended':
      await db.videoSessions.markEnded(payload.room.name, {
        duration: payload.meeting_duration,
      });
      break;
    case 'participant.joined':
      await db.videoSessions.addParticipant(payload.room.name, payload.participant.user_name);
      break;
  }

  res.status(200).end();
});

Сроки

Базовая интеграция Daily.co с созданием комнаты и iframe — 1–2 дня. С токенами, webhooks и записью звонков — 3–4 дня.