LiveBroadcasts: update

방송을 업데이트합니다. 예를 들어 liveBroadcast 리소스의 contentDetails 객체에 정의된 브로드캐스트 설정을 수정할 수 있습니다.

일반적인 사용 사례

요청

HTTP 요청

PUT https://www.googleapis.com/youtube/v3/liveBroadcasts

승인

이 요청에는 다음 범위 중 하나 이상에 대한 승인이 필요합니다. 인증 및 승인에 대해 자세히 알아보려면 OAuth 2.0 승인 구현을 참고하세요.

범위
https://www.googleapis.com/auth/youtube
https://www.googleapis.com/auth/youtube.force-ssl

매개변수

다음 표에는 이 쿼리가 지원하는 매개변수가 나와 있습니다. 나열된 모든 매개변수는 쿼리 매개변수입니다.

매개변수
필수 매개변수
part string
part 매개변수는 이 작업에서 두 가지 용도로 사용됩니다. 쓰기 작업에서 설정할 속성과 API 응답에 포함할 속성을 식별합니다.

매개변수 값에 포함할 수 있는 part 속성은 id, snippet, contentDetails, monetizationDetails, status입니다.

이 메서드는 매개변수 값이 지정하는 부분에 포함된 모든 변경 가능한 속성의 기존 값을 재정의합니다. 예를 들어 방송의 개인 정보 보호 상태는 status 부분에 정의되어 있습니다. 따라서 요청이 비공개 또는 일부 공개 방송을 업데이트하고 요청의 part 매개변수 값에 status 부분이 포함된 경우 방송의 공개 상태 설정이 요청 본문에서 지정하는 값으로 업데이트됩니다. 요청 본문에 값이 지정되지 않으면 기존 개인 정보 보호 설정이 삭제되고 브로드캐스트가 기본 개인 정보 보호 설정으로 되돌아갑니다.
선택적 매개변수
onBehalfOfContentOwner string
이 매개변수는 적절하게 승인된 요청에서만 사용할 수 있습니다.
참고: 이 매개변수는 YouTube 콘텐츠 파트너만 사용할 수 있습니다.

onBehalfOfContentOwner 매개변수는 요청의 승인 사용자 인증 정보가 매개변수 값에 지정된 콘텐츠 소유자를 대신하는 YouTube 콘텐츠 관리 시스템 (CMS) 사용자를 식별함을 나타냅니다. 이 매개변수는 여러 YouTube 채널을 소유하고 관리하는 YouTube 콘텐츠 파트너를 위해 마련되었습니다. 콘텐츠 소유자는 이 기능을 통해 각 개별 채널에 대한 사용자 인증 정보를 제공하지 않고도 한 번만 인증하면 모든 동영상 및 채널 데이터에 액세스할 수 있습니다. 사용자가 인증할 CMS 계정은 지정된 YouTube 콘텐츠 소유자에게 연결되어야 합니다.
onBehalfOfContentOwnerChannel string
이 매개변수는 적절하게 승인된 요청에서만 사용할 수 있습니다.
참고: 이 매개변수는 YouTube 콘텐츠 파트너만 사용할 수 있습니다.

onBehalfOfContentOwnerChannel 매개변수는 동영상이 추가되는 채널의 YouTube 채널 ID를 지정합니다. 이 매개변수는 요청에서 onBehalfOfContentOwner 매개변수의 값을 지정하는 경우에 필요하며 해당 매개변수와 함께만 사용할 수 있습니다. 또한 onBehalfOfContentOwner 매개변수가 지정하는 콘텐츠 소유자에 연결된 CMS 계정을 사용하여 요청을 승인해야 합니다. 마지막으로 onBehalfOfContentOwnerChannel 매개변수 값이 지정하는 채널은 onBehalfOfContentOwner 매개변수에서 지정하는 콘텐츠 소유자와 연결되어야 합니다.

이 매개변수는 여러 YouTube 채널을 소유하고 관리하는 YouTube 콘텐츠 파트너를 위해 마련되었습니다. 이 매개변수로 콘텐츠 소유자는 각 개별 채널에 승인 사용자 인증 정보를 제공할 필요 없이 한 번 인증하여 매개변수 값에 지정된 채널을 대신하여 작업을 수행합니다.

요청 본문

요청 본문에 liveBroadcast 리소스를 제공합니다. 해당 리소스의 경우:

  • 다음 속성에 값을 지정해야 합니다.

    • id
    • snippet.scheduledStartTime
    • contentDetails.monitorStream.enableMonitorStream
    • contentDetails.monitorStream.broadcastStreamDelayMs

  • 다음 속성에 값을 설정할 수 있습니다.

    • snippet.title
    • snippet.description
    • snippet.scheduledStartTime
    • snippet.scheduledEndTime
    • status.privacyStatus
    • contentDetails.monitorStream.enableMonitorStream
    • contentDetails.monitorStream.broadcastStreamDelayMs
    • contentDetails.enableAutoStart
    • contentDetails.enableAutoStop
    • contentDetails.enableClosedCaptions
    • contentDetails.enableDvr
    • contentDetails.enableEmbed
    • contentDetails.recordFromStart
    • monetizationDetails.cuepointSchedule.pauseAdsUntil

    업데이트 요청을 제출하는데 값이 있는 속성에 요청이 값을 지정하지 않은 경우 속성의 기존 값은 삭제됩니다.

응답

이 메서드는 성공하면 응답 본문에 liveBroadcast 리소스를 반환합니다.

오류

다음 표에는 이 메서드 호출에 대한 응답으로 API에서 반환할 수 있는 오류 메시지가 나와 있습니다. 자세한 내용은 오류 메시지를 참고하세요.

오류 유형 오류 세부정보 설명
forbidden (403) closedCaptionsTypeModificationNotAllowed contentDetails.closedCaptionsType 값은 브로드캐스트가 created 또는 ready 상태일 때만 수정할 수 있습니다.
forbidden (403) enabledModificationNotAllowed enabled 필드는 읽기 전용입니다.
forbidden (403) scheduleStrategyModificationNotAllowed scheduleStrategy 필드는 읽기 전용입니다.
forbidden (403) repeatIntervalSecsModificationNotAllowed repeatIntervalSecs 필드는 읽기 전용입니다.
forbidden (403) pauseAdsUntilModificationNotAllowed pauseAdsUntil 필드는 수정할 수 없습니다. 이 오류는 다음과 같은 이유로 발생할 수 있습니다.
  • monetizationDetails.cuepointSchedule.enabled 필드가 true로 설정되지 않았습니다. 이 필드는 YouTube 스튜디오를 통해서만 설정할 수 있습니다.
  • 브로드캐스트가 실시간 스트리밍 중이 아닙니다.
forbidden (403) enableAutoStartModificationNotAllowed contentDetails.enableAutoStart 값은 스트림이 비활성 상태이고 브로드캐스트가 created 또는 ready 상태일 때만 수정할 수 있습니다.
forbidden (403) enableClosedCaptionsModificationNotAllowed contentDetails.enableClosedCaptions 값은 브로드캐스트 상태가 created 또는 ready인 경우에만 수정할 수 있습니다.
forbidden (403) enableDvrModificationNotAllowed contentDetails.enableDvr 값은 브로드캐스트 상태가 created 또는 ready일 때만 수정할 수 있습니다.
forbidden (403) enableMonitorStreamModificationNotAllowed contentDetails.monitorStream.enableMonitorStream 값은 브로드캐스트 상태가 created 또는 ready일 때만 수정할 수 있습니다.
forbidden (403) recordFromStartModificationNotAllowed contentDetails.recordFromStart 값은 방송 상태가 created 또는 ready인 경우에만 수정할 수 있습니다.
insufficientPermissions insufficientLivePermissions 지정된 라이브 방송을 업데이트할 권한이 없는 요청입니다. 자세한 내용은 OAuth2 인증 구현을 참고하세요.
insufficientPermissions liveStreamingNotEnabled 요청을 승인한 사용자가 YouTube에서 라이브 동영상을 스트리밍할 수 없습니다. 사용자는 https://www.youtube.com/features에서 자세한 내용을 확인할 수 있습니다.
invalidValue (400) invalidAutoStart 라이브 스트림 리소스contentDetails.enableAutoStart 속성의 잘못된 값이 포함되어 있습니다. 영구 브로드캐스트의 enableAutoStart 설정은 수정할 수 없습니다.
invalidValue (400) invalidAutoStop 라이브 스트림 리소스contentDetails.enableAutoStop 속성의 잘못된 값이 포함되어 있습니다. 영구 브로드캐스트의 enableAutoStop 설정은 수정할 수 없습니다.
invalidValue (400) invalidDescription 라이브 스트림 리소스에서 snippet.description 속성에 유효한 값을 지정하지 않았습니다. snippet.description에는 최대 5,000자(영문 기준)까지 포함할 수 있습니다.
invalidValue (400) invalidEmbedSetting 라이브 스트림 리소스contentDetails.enable_embed 속성의 잘못된 값이 포함되어 있습니다. 이 방송은 삽입할 수 없습니다.
invalidValue (400) invalidEnableClosedCaptions liveBroadcast 리소스에서 contentDetails.enableClosedCaptions 속성의 값이 contentDetails.closedCaptionType 설정의 값과 호환되지 않습니다. 두 속성 중 하나만 포함하도록 리소스를 수정한 다음 요청을 다시 제출하세요.
invalidValue (400) invalidLatencyPreferenceOptions liveBroadcast 리소스에 잘못된 contentDetails.latencyPreference 속성 값이 포함되어 있습니다. 이 지연 시간 환경설정에서는 일부 설정이 지원되지 않습니다.
invalidValue (400) invalidPauseAdsUntil 라이브 스트림 리소스monetizationDetails.cuepointSchedule.pauseAdsUntil 속성의 잘못된 값이 포함되어 있습니다. 이 오류는 다음과 같은 이유로 발생할 수 있습니다.
  • monetizationDetails.cuepointSchedule.pauseAdsUntil 값이 ISO 8601 (YYYY-MM-DDThh:mm:ss.sZ) 형식으로 지정되지 않았습니다.
  • monetizationDetails.cuepointSchedule.pauseAdsUntil 값이 미래가 아닙니다.
  • monetizationDetails.cuepointSchedule.pauseAdsUntil 값이 현재 시간에서 10분 이상 떨어졌습니다.
invalidValue (400) invalidPrivacyStatus liveBroadcast 리소스에 유효한 개인 정보 보호 상태가 지정되지 않았습니다. 유효한 privacyStatus을 참고하세요.
invalidValue (400) invalidProjection 라이브 스트림 리소스contentDetails.projection 속성의 잘못된 값이 포함되어 있습니다. 영구 브로드캐스트의 프로젝션은 360으로 설정할 수 없습니다.
invalidValue (400) invalidScheduledEndTime 라이브 스트림 리소스snippet.scheduledEndTime 속성의 잘못된 값이 포함되어 있습니다. 예약된 종료 시간은 예약된 시작 시간 이후여야 합니다.
invalidValue (400) invalidScheduledStartTime 라이브 스트림 리소스snippet.scheduledStartTime 속성의 잘못된 값이 포함되어 있습니다. 예약된 시작 시간은 미래의 날짜여야 합니다.
invalidValue (400) invalidTitle 라이브 스트림 리소스에서 snippet.title 속성에 유효한 값을 지정하지 않았습니다. snippet.title는 1~100자(영문 기준)여야 합니다.
notFound (404) liveBroadcastNotFound liveBroadcast 리소스에 지정된 id 속성이 브로드캐스트를 식별하지 못했습니다.
required (400) broadcastStreamDelayMsRequired liveBroadcast 리소스contentDetails.monitorStream.broadcastStreamDelayMs 속성을 지정하지 않았습니다.
required (400) enableMonitorStreamRequired liveBroadcast 리소스contentDetails.monitorStream.enableMonitorStream 속성을 지정하지 않았습니다.
required (400) idRequired 라이브 스트림 리소스id 속성의 값을 포함하고 지정해야 합니다.
required (400) scheduledEndTimeRequired liveBroadcast 리소스snippet.scheduledEndTime 속성을 지정하지 않았습니다.
required (400) scheduledStartTimeRequired liveBroadcast 리소스snippet.scheduledStartTime 속성을 지정하지 않았습니다.

사용해 보기

APIs Explorer를 사용하여 이 API를 호출하고 API 요청 및 응답을 확인합니다.