방송을 업데이트합니다. 예를 들어 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 필드는 수정할 수 없습니다.
이 오류는 다음과 같은 이유로 발생할 수 있습니다.
|
forbidden (403) |
enableAutoStartModificationNotAllowed |
contentDetails.enableAutoStart 값은 스트림이 비활성 상태이고 브로드캐스트가 created 또는 ready 상태일 때만 수정할 수 있습니다. |
forbidden (403) |
enableClosedCaptionsModificationNotAllowed |
contentDetails.enableClosedCaptions 값은 브로드캐스트 상태가 created 또는 ready 인 경우에만 수정할 수 있습니다. |
forbidden (403) |
enableDvrModificationNotAllowed |
contentDetails. 값은 브로드캐스트 상태가 created 또는 ready 일 때만 수정할 수 있습니다. |
forbidden (403) |
enableMonitorStreamModificationNotAllowed |
contentDetails. 값은 브로드캐스트 상태가 created 또는 ready 일 때만 수정할 수 있습니다. |
forbidden (403) |
recordFromStartModificationNotAllowed |
contentDetails. 값은 방송 상태가 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 속성의 잘못된 값이 포함되어 있습니다.
이 오류는 다음과 같은 이유로 발생할 수 있습니다.
|
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. 속성을 지정하지 않았습니다. |
required (400) |
enableMonitorStreamRequired |
liveBroadcast 리소스가 contentDetails. 속성을 지정하지 않았습니다. |
required (400) |
idRequired |
라이브 스트림 리소스는 id 속성의 값을 포함하고 지정해야 합니다. |
required (400) |
scheduledEndTimeRequired |
liveBroadcast 리소스가 snippet.scheduledEndTime 속성을 지정하지 않았습니다. |
required (400) |
scheduledStartTimeRequired |
liveBroadcast 리소스가 snippet.scheduledStartTime 속성을 지정하지 않았습니다. |
사용해 보기
APIs Explorer를 사용하여 이 API를 호출하고 API 요청 및 응답을 확인합니다.