Skip to content

Instantly share code, notes, and snippets.

@lokeshh
Created July 13, 2017 15:34
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 1 You must be signed in to fork a gist
  • Save lokeshh/40eea3608d7af3d2fd1f07671b12bcd9 to your computer and use it in GitHub Desktop.
Save lokeshh/40eea3608d7af3d2fd1f07671b12bcd9 to your computer and use it in GitHub Desktop.
#!/usr/bin/python
import httplib2
import os
import sys
from apiclient.discovery import build
from apiclient.errors import HttpError
from oauth2client.client import flow_from_clientsecrets
from oauth2client.file import Storage
from oauth2client.tools import argparser, run_flow
# The CLIENT_SECRETS_FILE variable specifies the name of a file that contains
# the OAuth 2.0 information for this application, including its client_id and
# client_secret. You can acquire an OAuth 2.0 client ID and client secret from
# the {{ Google Cloud Console }} at
# {{ https://cloud.google.com/console }}.
# Please ensure that you have enabled the YouTube Data API for your project.
# For more information about using OAuth2 to access the YouTube Data API, see:
# https://developers.google.com/youtube/v3/guides/authentication
# For more information about the client_secrets.json file format, see:
# https://developers.google.com/api-client-library/python/guide/aaa_client_secrets
CLIENT_SECRETS_FILE = "client_secrets.json"
# This OAuth 2.0 access scope allows for full read/write access to the
# authenticated user's account.
YOUTUBE_READ_WRITE_SCOPE = "https://www.googleapis.com/auth/youtube"
YOUTUBE_API_SERVICE_NAME = "youtube"
YOUTUBE_API_VERSION = "v3"
# This variable defines a message to display if the CLIENT_SECRETS_FILE is
# missing.
MISSING_CLIENT_SECRETS_MESSAGE = """
WARNING: Please configure OAuth 2.0
To make this sample run you will need to populate the client_secrets.json file
found at:
%s
with information from the {{ Cloud Console }}
{{ https://cloud.google.com/console }}
For more information about the client_secrets.json file format, please visit:
https://developers.google.com/api-client-library/python/guide/aaa_client_secrets
""" % os.path.abspath(os.path.join(os.path.dirname(__file__),
CLIENT_SECRETS_FILE))
def get_authenticated_service(args):
flow = flow_from_clientsecrets(CLIENT_SECRETS_FILE,
scope=YOUTUBE_READ_WRITE_SCOPE,
message=MISSING_CLIENT_SECRETS_MESSAGE)
storage = Storage("%s-oauth2.json" % sys.argv[0])
credentials = storage.get()
if credentials is None or credentials.invalid:
credentials = run_flow(flow, storage, args)
return build(YOUTUBE_API_SERVICE_NAME, YOUTUBE_API_VERSION,
http=credentials.authorize(httplib2.Http()))
# Create a liveBroadcast resource and set its title, scheduled start time,
# scheduled end time, and privacy status.
def insert_broadcast(youtube, options):
insert_broadcast_response = youtube.liveBroadcasts().insert(
part="snippet,status",
body=dict(
snippet=dict(
title=options.broadcast_title,
scheduledStartTime=options.start_time,
scheduledEndTime=options.end_time
),
status=dict(
privacyStatus=options.privacy_status
)
)
).execute()
snippet = insert_broadcast_response["snippet"]
print "Broadcast '%s' with title '%s' was published at '%s'." % (
insert_broadcast_response["id"], snippet["title"], snippet["publishedAt"])
return insert_broadcast_response["id"]
# Create a liveStream resource and set its title, format, and ingestion type.
# This resource describes the content that you are transmitting to YouTube.
def insert_stream(youtube, options):
insert_stream_response = youtube.liveStreams().insert(
part="snippet,cdn",
body=dict(
snippet=dict(
title=options.stream_title
),
cdn=dict(
format="1080p",
ingestionType="rtmp"
)
)
).execute()
snippet = insert_stream_response["snippet"]
print "Stream '%s' with title '%s' was inserted." % (
insert_stream_response["id"], snippet["title"])
return insert_stream_response["id"]
# Bind the broadcast to the video stream. By doing so, you link the video that
# you will transmit to YouTube to the broadcast that the video is for.
def bind_broadcast(youtube, broadcast_id, stream_id):
bind_broadcast_response = youtube.liveBroadcasts().bind(
part="id,contentDetails",
id=broadcast_id,
streamId=stream_id
).execute()
print "Broadcast '%s' was bound to stream '%s'." % (
bind_broadcast_response["id"],
bind_broadcast_response["contentDetails"]["boundStreamId"])
if __name__ == "__main__":
argparser.add_argument("--broadcast-title", help="Broadcast title",
default="New Broadcast")
argparser.add_argument("--privacy-status", help="Broadcast privacy status",
default="private")
argparser.add_argument("--start-time", help="Scheduled start time",
default='2018-01-30T00:00:00.000Z')
argparser.add_argument("--end-time", help="Scheduled end time",
default='2018-01-31T00:01:00.000Z')
argparser.add_argument("--stream-title", help="Stream title",
default="New Stream")
args = argparser.parse_args()
youtube = get_authenticated_service(args)
try:
broadcast_id = insert_broadcast(youtube, args)
# stream_id = insert_stream(youtube, args)
stream_id = 'CNSDdM72mVvwG_Tn6ptkog1499143870123540'
bind_broadcast(youtube, broadcast_id, stream_id)
except HttpError, e:
print "An HTTP error %d occurred:\n%s" % (e.resp.status, e.content)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment