LiveBroadcasts: update

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

일반적인 사용 사례

요청

HTTP 요청

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

승인

이 요청에는 다음 범위 중 최소 하나를 사용하여 인증이 필요합니다. (인증 및 승인에 대해 자세히 알아보기)

범위
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 liveBroadcast 리소스에 잘못된 contentDetails.enableAutoStart 속성 값이 포함되어 있습니다. 영구 브로드캐스트의 enableAutoStart 설정은 수정할 수 없습니다.
invalidValue (400) invalidAutoStop liveBroadcast 리소스에 잘못된 contentDetails.enableAutoStop 속성 값이 포함되어 있습니다. 영구 브로드캐스트의 enableAutoStop 설정은 수정할 수 없습니다.
invalidValue (400) invalidDescription liveBroadcast 리소스snippet.description 속성에 유효한 값을 지정하지 않았습니다. snippet.description에는 최대 5,000자(영문 기준)까지 포함할 수 있습니다.
invalidValue (400) invalidEmbedSetting liveBroadcast 리소스에 잘못된 contentDetails.enable_embed 속성 값이 포함되어 있습니다. 이 브로드캐스트를 삽입할 수 없습니다.
invalidValue (400) invalidEnableClosedCaptions liveBroadcast 리소스에서 contentDetails.enableClosedCaptions 속성의 값이 contentDetails.closedCaptionType 설정 값과 호환되지 않습니다. 두 속성 중 하나만 포함하도록 리소스를 수정한 후 요청을 다시 제출하세요.
invalidValue (400) invalidLatencyPreferenceOptions liveBroadcast 리소스에 잘못된 contentDetails.latencyPreference 속성 값이 포함되어 있습니다. 이 지연 시간 환경설정에서는 일부 설정이 지원되지 않습니다.
invalidValue (400) invalidPauseAdsUntil liveBroadcast 리소스에 잘못된 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 liveBroadcast 리소스에 잘못된 contentDetails.projection 속성 값이 포함되어 있습니다. 영구 브로드캐스트의 프로젝션은 360으로 설정할 수 없습니다.
invalidValue (400) invalidScheduledEndTime liveBroadcast 리소스에 잘못된 snippet.scheduledEndTime 속성 값이 포함되어 있습니다. 예약된 종료 시간은 예정된 시작 시간 이후여야 합니다.
invalidValue (400) invalidScheduledStartTime liveBroadcast 리소스에 잘못된 snippet.scheduledStartTime 속성 값이 포함되어 있습니다. 예약된 시작 시간은 미래여야 합니다.
invalidValue (400) invalidTitle liveBroadcast 리소스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 liveBroadcast 리소스id 속성 값을 포함하고 지정해야 합니다.
required (400) scheduledEndTimeRequired liveBroadcast 리소스snippet.scheduledEndTime 속성을 지정하지 않았습니다.
required (400) scheduledStartTimeRequired liveBroadcast 리소스snippet.scheduledStartTime 속성을 지정하지 않았습니다.

사용해 보기

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