Visão geral da API YouTube Live Streaming

Com a API YouTube Live Streaming, você pode criar, atualizar e gerenciar eventos ao vivo no YouTube. Usando a API, você pode agendar eventos (transmissões) e associá-los a streams de vídeo, que representam o conteúdo da transmissão real.

A API de transmissão ao vivo é composta por componentes da API de dados do YouTube e da API do Content ID do YouTube. A API Data permite que os usuários do YouTube gerenciem suas contas do YouTube, enquanto o YouTube Content ID API permite interações com o sistema de gerenciamento de direitos do YouTube. No entanto, todos os recursos que compõem a API Live Streaming são usados apenas para criar e gerenciar eventos ao vivo.

Este documento é destinado a desenvolvedores que desejam criar aplicativos para facilitar a transmissão ao vivo no YouTube. Ele explica os conceitos básicos do YouTube e da própria API. Também fornece uma visão geral das diferentes funções que a API suporta.

Principais conceitos

transmissões
Uma transmissão representa um evento que pode ser assistido no YouTube no momento em que ele acontece. As transmissões também podem ser gravadas e salvas como vídeos do YouTube para que os usuários possam assisti-los depois que acontecem.
córregos
Um stream identifica o conteúdo de áudio e vídeo que está sendo comunicado ao YouTube. Cada transmissão está associada a um stream de vídeo.
pontos de inserção
Um marcador representa um intervalo de anúncio que pode ser inserido em uma transmissão ao vivo.

Casos de uso da API

A lista abaixo sugere várias maneiras de usar a API em seu aplicativo:

  • Agende transmissões e defina configurações de transmissão. Seu aplicativo pode permitir que os usuários predefinam configurações de transmissão e selecionem as configurações que serão aplicadas a uma determinada transmissão.

  • Associe streams de vídeo e transmissões.

  • Permita que as emissoras definam informações sobre uma transmissão e seu vídeo (usando a API YouTube Data) ao mesmo tempo.

  • Simplifique as transições entre os estados de transmissão (testing, live etc.) e permita que os usuários insiram marcadores.

Antes de começar

  1. Você precisa de uma Conta do Google para acessar o Google API Console, solicitar uma chave de API e registrar seu aplicativo.

  2. Registre seu aplicativo no Google para que ele possa enviar solicitações de API.

  3. Depois de registrar o aplicativo, selecione YouTube Data API como um dos serviços que o aplicativo usa:

    1. Acesse API Console e selecione o projeto que você acabou de registrar.
    2. Acesse a página APIs ativadas. Na lista de APIs, certifique-se de que o status é ATIVADO para a API YouTube Data v3 e, se você for um Parceiro de conteúdo do YouTube, para a API Content ID do YouTube.

  4. Familiarize-se com os conceitos fundamentais do formato de dados JSON (JavaScript Object Notation, Notação de objeto do JavaScript). JSON é um formato de dados comum e independente de linguagem que fornece uma representação de texto simples de estruturas de dados arbitrárias. Para mais informações, acesse json.org.

Como autorizar solicitações de API

Como mencionado acima, a API de transmissão ao vivo usa uma funcionalidade que é tecnicamente parte da API de dados do YouTube ou da API do Content ID do YouTube. Você pode usar a API Content ID para fornecer ao YouTube metadados e informações de propriedade e de política para seus recursos. (a transmissão de vídeo ao vivo é um exemplo de recurso). A API também permite que você reivindique vídeos e defina políticas de anúncios para seus vídeos.

Esta seção explica os requisitos de autorização para solicitações ao Content ID API, que são diferentes dos requisitos de autorização de outras solicitações Live Streaming API.

Ligando para Data API
A solicitação de API precisa ser autorizada pela Conta do Google proprietária do canal de transmissão do YouTube.
Ligando para Content ID API
A solicitação de API precisa ser autorizada por uma Conta do Google vinculada ao proprietário do conteúdo que tem o canal de transmissão do YouTube.

Recursos e tipos de recursos

Um recurso é uma entidade individual de dados com um identificador exclusivo. A tabela abaixo descreve os diferentes tipos de recursos com que você vai interagir usando o Live Streaming API. Tecnicamente, todos esses recursos são definidos como parte de YouTube Data API ou YouTube Content ID API. No entanto, os recursos liveBroadcast, liveStream e cuepoint são usados apenas para criar e gerenciar eventos ao vivo.

Recursos
liveBroadcast Contém informações sobre um evento que você está transmitindo no YouTube. Um recurso liveBroadcast é uma extensão de um recurso de vídeo do YouTube e define metadados de vídeo que seriam pertinentes a uma transmissão ao vivo, mas não para outros vídeos do YouTube.

Sendo assim, um liveBroadcast corresponde exatamente a um recurso de vídeo do YouTube. Na verdade, os recursos liveBroadcast e video compartilham o mesmo ID. Depois de criar a transmissão usando a API Live Streaming, você pode usar a API YouTube Data para fornecer metadados adicionais sobre o vídeo.
liveStream Contém informações sobre o fluxo de vídeo que você está transmitindo para o YouTube. O stream fornece o conteúdo que será transmitido aos usuários do YouTube. Depois de criado, um recurso liveStream pode ser vinculado exatamente a um recurso liveBroadcast. Da mesma forma, o recurso liveBroadcast só pode ser vinculado a um recurso liveStream.
cuepoint Insere um marcador no stream de vídeo de transmissão, o que pode acionar um intervalo de anúncio. Use o método liveBroadcasts.cuepoint para inserir um marcador durante uma transmissão.
video Representa um vídeo simples do YouTube. Como mencionado acima, um recurso liveBroadcast é uma extensão de um recurso video. Você pode usar a API de dados do YouTube para atualizar metadados sobre o vídeo, como o local da gravação ou as regiões em que a transmissão será vista.
videoAdvertisingOptions Define as configurações de publicidade para um vídeo (ou transmissão). Use YouTube Content ID API para definir as opções de publicidade.
asset Representa uma parte da propriedade intelectual, como um filme ou episódio de um show. Neste caso, a transmissão de vídeo é o recurso. Você vai usar o YouTube Content ID API para criar e gerenciar recursos do asset.
claim Vincula um vídeo a um recurso correspondente ao vídeo. Você cria uma reivindicação usando YouTube Content ID API para se identificar como o proprietário da transmissão de vídeo.
policy Define regras que especificam as circunstâncias nas quais você deseja que seu conteúdo seja visualizado no YouTube ou impedido de ser exibido no YouTube. Você precisa aplicar uma política para sua transmissão de vídeo e também pode especificar uma política que o YouTube aplicará a vídeos enviados por usuários que correspondam à sua transmissão de vídeo.

Operações suportadas

A tabela a seguir mostra os diferentes métodos que a API suporta:

Operações
list Recupera (GET) uma lista vazia ou com recursos.
insert Cria (POST) um novo recurso.
update Modifica (PUT) um recurso existente para propagar os dados em sua solicitação.
bind Vincula um recurso liveBroadcast a um recurso liveStream ou remove esse vínculo.
transition Altera o status de um recurso liveBroadcast e inicia todos os processos associados ao novo status. Por exemplo, quando você faz a transição do status de uma transmissão para testing, o YouTube começa a transmitir vídeos para o stream do monitor dessa transmissão.
delete Remove (DELETE) um recurso específico.

A tabela abaixo identifica as operações que são compatíveis com diferentes tipos de recursos. Operações que inserem, atualizam ou excluem recursos sempre precisam de autorização do usuário. Em alguns casos, os métodos list oferecem suporte a solicitações autorizadas e não autorizadas, em que as solicitações não autorizadas apenas recuperam dados públicos, enquanto as solicitações autorizadas também podem recuperar informações restritas ao usuário autenticado no momento.

Operações suportadas
list insert update bind transition cuepoint delete
liveBroadcast
liveStream

Recursos parciais

A API permite e, na prática, requer a recuperação de recursos parciais para que os aplicativos evitem a transferência, a análise e o armazenamento de dados desnecessários. Esta abordagem também garante que a API use a rede, a CPU e os recursos da memória de modo mais eficiente.

O parâmetro part é obrigatório para qualquer solicitação de API que recupera ou retorne um recurso YouTube Data API. O parâmetro identifica uma ou mais propriedades do recurso de alto nível (não testadas) que devem ser incluídas em uma resposta da API. Por exemplo, um recurso liveStream tem as seguintes partes:

  • snippet
  • cdn
  • status

Todas essas partes são objetos que contêm propriedades agrupadas, e esses objetos são considerados grupos de campos de metadados que podem (ou não) ser recuperados pelo servidor da API. Como o parâmetro part exige que você selecione os componentes do recurso que seu aplicativo realmente usa. Esse requisito tem dois propósitos importantes:

  • Reduz a latência evitando que o servidor da API perca tempo recuperando campos de metadados que não são usados por seu aplicativo.
  • Reduz o uso de largura de banda diminuindo (ou eliminando) a quantidade de dados desnecessários que seu aplicativo pode recuperar.

Com o passar do tempo, à medida que os recursos adicionam mais partes, esses benefícios só irão aumentar, uma vez que seu aplicativo não solicitará propriedades recém-introduzidas não suportadas por ele.

Dicas e práticas recomendadas

Reivindicar seu conteúdo

Caso queira exibir anúncios durante sua transmissão, reivindique a transmissão de vídeo antes do início do evento. Para reivindicar conteúdo, você precisa ser um Parceiro de Conteúdo do YouTube que participa do programa Content ID.

O processo para reivindicar sua transmissão de vídeo ao vivo é diferente do processo normal para reivindicar um vídeo. Crie a reivindicação de um vídeo ao vivo antes mesmo de ele existir para reivindicá-lo. A API oferece suporte a isso, e o documento life of a broadcast explica as chamadas YouTube Content ID API que permitem criar a reivindicação.

Visualizar e testar seu conteúdo

Ao receber seu stream de vídeo de entrada, o YouTube pode transmitir esse vídeo em dois streams de saída diferentes:

  • O stream de monitor permite que você visualize (e teste) sua transmissão de vídeo. Ele constitui um stream particular que somente você pode acessar. Você só pode fazer a transição de uma transmissão para a fase testing se o stream do monitor da transmissão estiver ativado. O stream do monitor não exibe intervalos no anúncio.

  • O stream de transmissão é o stream que seu público pode visualizarco. Você pode definir o status de privacidade da transmissão como public, private ou unlisted. (a transmissão particular fica visível apenas aos usuários que foram explicitamente convidados a assisti-la, enquanto uma transmissão não listada fica visível a qualquer pessoa que possui um link para visualizá-la).

    Você pode optar por atrasar o stream de transmissão de modo que ele não seja executado simultaneamente com o stream de monitor. Ao atrasar o stream de transmissão, você pode ter maior controle do tempo que você insere marcadores na transmissão.

    No entanto, quando você atrasa o stream de transmissão, seus apresentadores ao vivo podem enfrentar dificuldades para interagirem com seu público. Além disso, o atraso da transmissão aumenta a probabilidade de que os espectadores descubram detalhes importantes sobre o evento a partir de outras fontes de sua transmissão. Por exemplo, se você estiver transmitindo um evento esportivo com um atraso de 60 segundos, os espectadores poderão ver momentos críticos do evento de outras fontes de notícias em tempo real antes de realmente vê-los na transmissão.

O YouTube recomenda que você ative o stream de monitor para sua transmissão para que consiga testar seu conteúdo. Você deve escolher se também atrasará sua transmissão porque deseja controlar o tempo dos marcadores ou porque deseja interagir com seu público ou fornecer cobertura de um evento em tempo real.

Exibir anúncios intermediários durante uma transmissão

Durante uma transmissão, você pode inserir um marcador para indicar que um intervalo de anúncio precisa começar na transmissão assim que possível ou em um horário especificado. Com o intervalo de anúncio, o YouTube pode veicular anúncios intermediários durante a transmissão.

Os intervalos de anúncio têm as seguintes características:

  1. Ele tem um período predefinido, que você define usando a propriedade durationSecs do recurso cuepoint. Após o término do intervalo de anúncio, os espectadores retornam à transmissão ao vivo.

  2. Quando acontece um intervalo de anúncio, um anúncio só é reproduzido no player de vídeo para os espectadores que estão assistindo a transmissão quando o marcador é inserido. Um anúncio não é exibido quando os espectadores atualizam a página em que a transmissão está sendo reproduzida ou quando os visitantes começam a assistir à transmissão depois que o marcador é inserido.

A sequência de passos abaixo reflete a prática recomendada para a inserção de um intervalo no anúncio durante sua transmissão:

Definir ajustes de horário

Ao inserir um marcador, você pode especificar que ele precisa ser inserido imediatamente ou em um ponto específico da transmissão. Suas opções dependem de o stream de transmissão do vídeo estar atrasado.

  • Se o stream de transmissão não estiver atrasado, será possível inserir o marcador imediatamente ou usar a propriedade walltimeMs para que o intervalo de anúncio comece em um momento específico.

    • Para iniciar o intervalo de anúncio imediatamente, chame o método liveBroadcasts.cuepoint. No recurso do corpo da solicitação, defina o valor da propriedade insertionOffsetTimeMs como 0 ou não especifique um valor para essa propriedade e não especifique um valor para a propriedade walltimeMs.

      Importante:os espectadores não veem o conteúdo do anúncio resultante imediatamente. Pode haver um atraso de cerca de 30 segundos antes que o conteúdo do anúncio fique visível para os usuários. Durante esse atraso, seu stream de transmissão ainda permanecerá visível para os espectadores, e você precisa assistir o stream de transmissão para determinar quando o conteúdo do anúncio realmente é exibido em vez do stream de monitoramento.

    • Para iniciar o intervalo de anúncio em um momento específico, chame o método liveBroadcasts.cuepoint e use a propriedade walltimeMs para especificar o tempo desejado. O valor da propriedade é um número inteiro que representa um carimbo de data/hora de época.

  • Se o stream de transmissão estiver atrasado, você vai poder inserir o marcador imediatamente, conforme descrito acima, ou especificar um horário conforme descrito acima ou um ajuste de horário para determinar quando o intervalo de anúncio vai começar. O ajuste de horário especifica um ponto na transmissão em que os espectadores podem ver um anúncio.

    O valor do deslocamento é medido em milissegundos desde o início do stream de monitoramento da transmissão. Observe que, se a transmissão tiver uma fase de teste, o stream de monitoramento vai começar quando a transmissão fizer a transição para o status testing. Caso contrário, o stream de monitoramento começará quando a transmissão mudar para o status live.

    Ao inserir um marcador, defina a propriedade insertionOffsetTimeMs do recurso cuepoint com o deslocamento desejado.

Calcular o valor do ajuste de horário

Para recuperar o valor do deslocamento, chame a função getCurrentTime da API do Player do YouTube para o player que está reproduzindo o stream de monitoramento. Use o valor recuperado para inserir o marcador no stream de transmissão nesse momento.

Os valores possíveis para o ajuste de horário podem ser calculados como o seguinte intervalo:

[(elapsed_time - broadcast_delay + Δ), (elapsed_time - Δ)]

O Δ é um buffer de cinco segundos no início e no final dos possíveis ajustes de horário quando o YouTube não pode inserir precisamente um marcador. Exemplo:

  • Uma transmissão tem uma fase de teste de cinco minutos.
  • O stream de transmissão está atrasado em 60 segundos após o stream de monitor.
  • A emissora está inserindo o marcador quatro minutos após as transições da transmissão para o status live. (isso corresponde a três minutos depois de o stream de transmissão ficar visível).

Nesse caso, o intervalo possível de ajustes de horário é [(485,000), (535,000)].

Esses horários são especificados em milissegundos e são calculados com base nos seguintes valores:

  • elapsed_time=540000: o stream de monitoramento foi executado por nove minutos (540 segundos e 540.000 milissegundos) quando o método liveBroadcasts.cuepoint é chamado.
  • broadcast_delay=60000 – O stream de transmissão tem atraso de 60 segundos, ou 60.000 milissegundos.
  • Δ=5000: o buffer de cinco segundos quando o marcador não pode ser inserido com segurança.

Solucionar problemas e erros

As seguintes diretrizes explicam como solucionar problemas específicos que possam surgir. Consulte também a documentação de erros para ver as listas de erros que cada método de API pode retornar.

  • Quando uma transmissão muda de um status para outro, ela pode ser temporariamente transferida com outro status enquanto o YouTube conclui as ações associadas à transição. Por exemplo, se você enviar uma solicitação liveBroadcasts.transition para mudar o status de uma transmissão de ready para testing, o YouTube vai definir o status da transmissão como testStarting e concluir as ações associadas à mudança. Quando todas essas ações forem concluídas, o YouTube vai atualizar o status da transmissão para testing, indicando que a transição foi concluída.

    Se a transmissão ficar presa com um status testStarting ou liveStarting, chame o método liveBroadcasts.delete e exclua a transmissão. Crie uma nova transmissão, vincule-a a seu stream ao vivo e continue com o processo de teste.

    Conforme observado na documentação do método liveBroadcasts.transition, confirme se o valor da propriedade status.streamStatus do stream vinculado à transmissão é active antes de chamar esse método.