Create Publishing Schedule

Creates a publishing scheduleRefers to a configuration that identifies a live channel or live event and a publishing target. Use a publishing schedule to syndicate a live channel or a live event to a social media platform..

Request

Request syntax:

POST /syndication-schedule

Request body parameters:

Pass the following request body parameters:

NameData TypeDescription
content_id RequiredStringIdentifies a live channel or live event by its system-defined ID.
content_type RequiredStringDetermines whether the content_id parameter identifies a live channel or a live event. Valid values are: _ e: Live Event _ c: Live Channel
regionStringIdentifies a publishing location by its system-defined ID. A publishing location determines where your stream will be converted to a feed that may be ingested by the social media or content distribution platform identified by the publishing target. Set this property to an empty string to use the default output location. Use the Get All Publishing Locations endpoint to retrieve a list of regions and their system-defined IDs.
scte35_enabledIntegerHLS (Push/Pull) or Zixi (Push) Determines whether SCTE-35 markers will be inserted into the published stream. Valid values are: _ 0: Disabled. _ 1: Enabled.
source_stream DeprecatedStringThis parameter has been deprecated.
source_url_paramsDictionaryDefine a key-value pair for each desired query string parameter. Syndication Publishing adds these parameters to the playback URL published to your social media or content distribution platform. Example: 'source_url_params': { 'delay': '20', 'ad': 'sportcreatives' }
syndication_target_id RequiredStringIdentifies a publishing targetRefers to a configuration that identifies the URL to which your content may be published. A publishing schedule leverages a publishing target configuration to syndicate a live channel or a live event to a social media platform. by its system-defined ID. Use the Get Multiple Publishing Targets endpoint to retrieve a list of publishing targets and their system-defined IDs.
target_platform_configDictionaryHLS (Push/Pull) or Zixi (Push) Contains a social media or content distribution platform's setting.
url_params_activeBooleanDetermines whether our service may add your custom query string parameters to the playback URLs defined within the manifest file.
video_qualityStringDetermines the stream quality that will be published to the social media or content distribution platform. Valid values are: highmediumlow

target_platform_config Dictionary

The target_platform_config dictionary describes a social media or content distribution platform's settings through the following properties:

NameData TypeDescription
integrated_descriptionStringFacebook or YouTube (Integrated Authentication) Determines the video's description.
integrated_titleStringFacebook or YouTube (Integrated Authentication) Determines the video's title.
integrated_yt_made_for_kidsBooleanYouTube (Integrated Authentication) Only Determines whether the video is appropriate for kids.
integrated_yt_privacyStringYouTube (Integrated Authentication) Only Sets the video's privacy level. Valid values are: publicprivateunlisted
raysList of string valuesHLS (Push/Pull) Contains a list of the ray(s) that will be published. Use the Get Rays endpoint to retrieve a list of rays (all) and their names (ray_name).

Response

The response for a successful request contains the following properties:

NameData TypeDescription
@idStringIndicates the relative path to an endpoint that returns this publishing schedule.
@typeStringReturns SyndicationSchedule.
audio_trackStringIndicates the name of the audio track that will be published.
content_idStringIdentifies a live channel or live event by its system-defined ID.
content_typeStringIndicates whether the content_id parameter identifies a live channel or a live event. Valid values are: _ e: Live Event _ c: Live Channel
err_msgStringIndicates the publishing schedule's last error message. The system generates an error message whenever the publishing schedule's status is set to error.
idStringIndicates the system-defined ID for the publishing schedule.
last_statusStringIndicates the timestamp, in Unix time (milliseconds), at which the publishing schedule's status was last updated.
regionStringIndicates the location where your stream will be converted to a feed that may be ingested by the social media or content distribution platform identified by the publishing target. An empty string identifies the default output location.
region_auto_selectedBooleanIndicates whether this publishing schedule's publishing location is set to auto selected.
scte35_enabledIntegerHLS (Push/Pull) or Zixi (Push) Indicates whether SCTE-35 markers will be inserted into the published stream. Valid values are: _ 0: Disabled. _ 1: Enabled.
source_stream DeprecatedStringThis parameter has been deprecated.
source_url_paramsDictionaryContains key-value pairs for query string parameters. Syndication Publishing adds these parameters to the playback URL published to your social media or content distribution platform.
startIntegerIndicates the timestamp, in Unix time (milliseconds), at which the publishing schedule was last started.
statusStringIndicates the publishing schedule's status. Valid values are: activestoppingstoppedschedulederror
stopIntegerIndicates the timestamp, in Unix time (milliseconds), for either of the following conditions: _ Active Publishing Schedule: Reports one year from the start time. _ Stopped Publishing Schedule: Reports the timestamp at which the publishing schedule entered the stopped state.
syndication_target_descriptionStringIndicates the description for the publishing target.
syndication_target_idStringIndicates the system-defined ID for the publishing targetRefers to a configuration that identifies the URL to which your content may be published. A publishing schedule leverages a publishing target configuration to syndicate a live channel or a live event to a social media platform..
target_platform_configDictionaryHLS (Push/Pull) or Zixi (Push) Contains a social media or content distribution platform's settings.
typeStringReturns downloader.
url_params_activeBooleanIndicates whether our service may add your custom query string parameters to the playback URLs defined within the manifest file.
video_qualityStringIndicates the stream quality that will be published to the social media or content distribution platform. Valid values are: highmediumlow

target_platform_config Dictionary

The target_platform_config dictionary describes a social media or content distribution platform's settings via the following properties:

NameData TypeDescription
broadcast_idStringReserved for internal use.
channel_id_pristineStringReserved for internal use.
hls_master_urlStringHLS (Pull) Only Indicates the URL to which our service will push a HLS stream once you start publishing to this target. You will need to configure the desired social media or content distribution platform to pull the stream using this URL.
integratedBooleanReserved for future use.
integrated_descriptionStringFacebook and YouTube (Integrated Authentication) Indicates the video's description.
integrated_titleStringFacebook and YouTube (Integrated Authentication) Indicates the video's title.
integrated_yt_made_for_kidsBooleanYouTube (Integrated Authentication) Only Indicates whether the video is appropriate for kids.
integrated_yt_privacyStringYouTube (Integrated Authentication) Only Indicates the video's privacy level. Valid values are: publicprivateunlisted
raysList of string valuesHLS (Push/Pull) Contains a list of the ray(s) that will be published. Use the Get Rays endpoint to retrieve a list of rays (all) and their names (ray_name).
stream_idStringReserved for internal use.

Sample Request/Response

The code below (Python 3) shows how to create a publishing schedule.

This code imports names from the api_auth module for V4 APIs (see below).

import json
import requests
from api_auth import APICredentials, APIParams

class PublishingSchedule:
    def __init__(self):
        self.host = "https://services.uplynk.com"

    def run(self):
        self._create_publishing_schedule()

    def _create_publishing_schedule(self):
        url = "{}{}".format(self.host, "/api/v4/syndication-schedule")

        publishing_target_id = 'd30f655670cb426c98cd28afb6291bf4'
        content_type = 'c'
        content_id = '1df8d13992cd4222a7343b8fafd89cd7'

        payload = {
            'syndication_target_id': publishing_target_id,
            'video_quality': 'medium',
            'content_id': content_id,
            'content_type': content_type
        }

        headers = {'Content-Type': 'application/json'}

        response = requests.post(
            url, params=APIParams(APICredentials()).get_params({}), data=json.dumps(payload), headers=headers
        )

        print(response.json())

PublishingSchedule().run()

Response:

{
	"@id": "/api/v4/syndication-schedule/e8d6b5cb940c40cc9ec6ad081a38f3f0",
	"@type": "SyndicationSchedule",
	"id": "e8d6b5cb940c40cc9ec6ad081a38f3f0",
	"start": "",
	"stop": "",
	"syndication_target_id": "d30f655670cb426c98cd28afb6291bf4",
	"status": "scheduled",
	"last_status": "",
	"err_msg": "",
	"type": "downloader",
	"video_quality": "medium",
	"audio_track": "en",
	"content_id": "1df8d13992cd4222a7343b8fafd89cd7",
	"content_type": "c",
	"syndication_target_description": "My Publishing Schedule"
}