# =================================================================================================== # _ __ _ _ # | |/ /__ _| | |_ _ _ _ _ __ _ # | ' . # # @ignore # =================================================================================================== require 'kaltura_client_base.rb' require 'kaltura_enums.rb' require 'kaltura_types.rb' module Kaltura # Manage access control profiles class KalturaAccessControlProfileService < KalturaServiceBase def initialize(client) super(client) end # Add new access control profile # @return [KalturaAccessControlProfile] def add(access_control_profile) kparams = {} client.add_param(kparams, 'accessControlProfile', access_control_profile) client.queue_service_action_call('accesscontrolprofile', 'add', 'KalturaAccessControlProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete access control profile by id # @return [] def delete(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('accesscontrolprofile', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get access control profile by id # @return [KalturaAccessControlProfile] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('accesscontrolprofile', 'get', 'KalturaAccessControlProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List access control profiles by filter and pager # @return [KalturaAccessControlProfileListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('accesscontrolprofile', 'list', 'KalturaAccessControlProfileListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update access control profile by id # @return [KalturaAccessControlProfile] def update(id, access_control_profile) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'accessControlProfile', access_control_profile) client.queue_service_action_call('accesscontrolprofile', 'update', 'KalturaAccessControlProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Add & Manage Access Controls class KalturaAccessControlService < KalturaServiceBase def initialize(client) super(client) end # Add new Access Control Profile # @return [KalturaAccessControl] def add(access_control) kparams = {} client.add_param(kparams, 'accessControl', access_control) client.queue_service_action_call('accesscontrol', 'add', 'KalturaAccessControl', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete Access Control Profile by id # @return [] def delete(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('accesscontrol', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get Access Control Profile by id # @return [KalturaAccessControl] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('accesscontrol', 'get', 'KalturaAccessControl', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List Access Control Profiles by filter and pager # @return [KalturaAccessControlListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('accesscontrol', 'list', 'KalturaAccessControlListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update Access Control Profile by id # @return [KalturaAccessControl] def update(id, access_control) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'accessControl', access_control) client.queue_service_action_call('accesscontrol', 'update', 'KalturaAccessControl', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Manage details for the administrative user class KalturaAdminUserService < KalturaServiceBase def initialize(client) super(client) end # Get an admin session using admin email and password (Used for login to the KMC application) # @return [string] def login(email, password, partner_id=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'email', email) client.add_param(kparams, 'password', password) client.add_param(kparams, 'partnerId', partner_id) client.queue_service_action_call('adminuser', 'login', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Reset admin user password and send it to the users email address # @return [] def reset_password(email) kparams = {} client.add_param(kparams, 'email', email) client.queue_service_action_call('adminuser', 'resetPassword', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Set initial users password # @return [KalturaAuthentication] def set_initial_password(hash_key, new_password) kparams = {} client.add_param(kparams, 'hashKey', hash_key) client.add_param(kparams, 'newPassword', new_password) client.queue_service_action_call('adminuser', 'setInitialPassword', 'KalturaAuthentication', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update admin user password and email # @return [KalturaAdminUser] def update_password(email, password, new_email='', new_password='', otp=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'email', email) client.add_param(kparams, 'password', password) client.add_param(kparams, 'newEmail', new_email) client.add_param(kparams, 'newPassword', new_password) client.add_param(kparams, 'otp', otp) client.queue_service_action_call('adminuser', 'updatePassword', 'KalturaAdminUser', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # api for getting analytics data class KalturaAnalyticsService < KalturaServiceBase def initialize(client) super(client) end # report query action allows to get a analytics data for specific query dimensions, metrics and filters. # @return [KalturaReportResponse] def query(filter, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('analytics', 'query', 'KalturaReportResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Manage application authentication tokens class KalturaAppTokenService < KalturaServiceBase def initialize(client) super(client) end # Add new application authentication token # @return [KalturaAppToken] def add(app_token) kparams = {} client.add_param(kparams, 'appToken', app_token) client.queue_service_action_call('apptoken', 'add', 'KalturaAppToken', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete application authentication token by ID # @return [] def delete(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('apptoken', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get application authentication token by ID # @return [KalturaAppToken] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('apptoken', 'get', 'KalturaAppToken', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List application authentication tokens by filter and pager # @return [KalturaAppTokenListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('apptoken', 'list', 'KalturaAppTokenListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Starts a new KS (kaltura Session) based on an application authentication token ID # @return [KalturaSessionInfo] def start_session(id, token_hash, user_id=KalturaNotImplemented, type=KalturaNotImplemented, expiry=KalturaNotImplemented, session_privileges=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'tokenHash', token_hash) client.add_param(kparams, 'userId', user_id) client.add_param(kparams, 'type', type) client.add_param(kparams, 'expiry', expiry) client.add_param(kparams, 'sessionPrivileges', session_privileges) client.queue_service_action_call('apptoken', 'startSession', 'KalturaSessionInfo', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update application authentication token by ID # @return [KalturaAppToken] def update(id, app_token) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'appToken', app_token) client.queue_service_action_call('apptoken', 'update', 'KalturaAppToken', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Base Entry Service class KalturaBaseEntryService < KalturaServiceBase def initialize(client) super(client) end # Generic add entry, should be used when the uploaded entry type is not known. # @return [KalturaBaseEntry] def add(entry, type=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'entry', entry) client.add_param(kparams, 'type', type) client.queue_service_action_call('baseentry', 'add', 'KalturaBaseEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Attach content resource to entry in status NO_MEDIA # @return [KalturaBaseEntry] def add_content(entry_id, resource) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'resource', resource) client.queue_service_action_call('baseentry', 'addContent', 'KalturaBaseEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Generic add entry using an uploaded file, should be used when the uploaded entry type is not known. # @return [KalturaBaseEntry] def add_from_uploaded_file(entry, upload_token_id, type=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'entry', entry) client.add_param(kparams, 'uploadTokenId', upload_token_id) client.add_param(kparams, 'type', type) client.queue_service_action_call('baseentry', 'addFromUploadedFile', 'KalturaBaseEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Anonymously rank an entry, no validation is done on duplicate rankings. # @return [] def anonymous_rank(entry_id, rank) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'rank', rank) client.queue_service_action_call('baseentry', 'anonymousRank', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Approve the entry and mark the pending flags (if any) as moderated (this will make the entry playable). # @return [] def approve(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('baseentry', 'approve', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Clone an entry with optional attributes to apply to the clone # @return [KalturaBaseEntry] def clone(entry_id, clone_options=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'cloneOptions', clone_options) client.queue_service_action_call('baseentry', 'clone', 'KalturaBaseEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Count base entries by filter. # @return [int] def count(filter=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.queue_service_action_call('baseentry', 'count', 'int', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete an entry. # @return [] def delete(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('baseentry', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaBaseEntry] def export(entry_id, storage_profile_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'storageProfileId', storage_profile_id) client.queue_service_action_call('baseentry', 'export', 'KalturaBaseEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Flag inappropriate entry for moderation. # @return [] def flag(moderation_flag) kparams = {} client.add_param(kparams, 'moderationFlag', moderation_flag) client.queue_service_action_call('baseentry', 'flag', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get base entry by ID. # @return [KalturaBaseEntry] def get(entry_id, version=-1) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'version', version) client.queue_service_action_call('baseentry', 'get', 'KalturaBaseEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get an array of KalturaBaseEntry objects by a comma-separated list of ids. # @return [array] def get_by_ids(entry_ids) kparams = {} client.add_param(kparams, 'entryIds', entry_ids) client.queue_service_action_call('baseentry', 'getByIds', 'KalturaBaseEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # This action delivers entry-related data, based on the user's context: access control, restriction, playback format and storage information. # @return [KalturaEntryContextDataResult] def get_context_data(entry_id, context_data_params) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'contextDataParams', context_data_params) client.queue_service_action_call('baseentry', 'getContextData', 'KalturaEntryContextDataResult', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # This action delivers all data relevant for player # @return [KalturaPlaybackContext] def get_playback_context(entry_id, context_data_params) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'contextDataParams', context_data_params) client.queue_service_action_call('baseentry', 'getPlaybackContext', 'KalturaPlaybackContext', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get remote storage existing paths for the asset. # @return [KalturaRemotePathListResponse] def get_remote_paths(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('baseentry', 'getRemotePaths', 'KalturaRemotePathListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Index an entry by id. # @return [int] def index(id, should_update=true) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'shouldUpdate', should_update) client.queue_service_action_call('baseentry', 'index', 'int', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List base entries by filter with paging support. # @return [KalturaBaseEntryListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('baseentry', 'list', 'KalturaBaseEntryListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List base entries by filter according to reference id # @return [KalturaBaseEntryListResponse] def list_by_reference_id(ref_id, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'refId', ref_id) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('baseentry', 'listByReferenceId', 'KalturaBaseEntryListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List all pending flags for the entry. # @return [KalturaModerationFlagListResponse] def list_flags(entry_id, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('baseentry', 'listFlags', 'KalturaModerationFlagListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Reject the entry and mark the pending flags (if any) as moderated (this will make the entry non-playable). # @return [] def reject(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('baseentry', 'reject', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update base entry. Only the properties that were set will be updated. # @return [KalturaBaseEntry] def update(entry_id, base_entry) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'baseEntry', base_entry) client.queue_service_action_call('baseentry', 'update', 'KalturaBaseEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update the content resource associated with the entry. # @return [KalturaBaseEntry] def update_content(entry_id, resource, conversion_profile_id=KalturaNotImplemented, advanced_options=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'resource', resource) client.add_param(kparams, 'conversionProfileId', conversion_profile_id) client.add_param(kparams, 'advancedOptions', advanced_options) client.queue_service_action_call('baseentry', 'updateContent', 'KalturaBaseEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update entry thumbnail from a different entry by a specified time offset (in seconds). # @return [KalturaBaseEntry] def update_thumbnail_from_source_entry(entry_id, source_entry_id, time_offset) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'sourceEntryId', source_entry_id) client.add_param(kparams, 'timeOffset', time_offset) client.queue_service_action_call('baseentry', 'updateThumbnailFromSourceEntry', 'KalturaBaseEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update entry thumbnail using URL. # @return [KalturaBaseEntry] def update_thumbnail_from_url(entry_id, url) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'url', url) client.queue_service_action_call('baseentry', 'updateThumbnailFromUrl', 'KalturaBaseEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update entry thumbnail using a raw jpeg file. # @return [KalturaBaseEntry] def update_thumbnail_jpeg(entry_id, file_data) kparams = {} kfiles = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kfiles, 'fileData', file_data) client.queue_service_action_call('baseentry', 'updateThumbnailJpeg', 'KalturaBaseEntry', kparams, kfiles) if (client.is_multirequest) return nil end return client.do_queue() end # Upload a file to Kaltura, that can be used to create an entry. # @return [string] def upload(file_data) kparams = {} kfiles = {} client.add_param(kfiles, 'fileData', file_data) client.queue_service_action_call('baseentry', 'upload', 'string', kparams, kfiles) if (client.is_multirequest) return nil end return client.do_queue() end end # Bulk upload service is used to upload & manage bulk uploads using CSV files. # This service manages only entry bulk uploads. class KalturaBulkUploadService < KalturaServiceBase def initialize(client) super(client) end # Aborts the bulk upload and all its child jobs # @return [KalturaBulkUpload] def abort(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('bulkupload', 'abort', 'KalturaBulkUpload', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Add new bulk upload batch job # Conversion profile id can be specified in the API or in the CSV file, the one in the CSV file will be stronger. # If no conversion profile was specified, partner's default will be used # @return [KalturaBulkUpload] def add(conversion_profile_id, csv_file_data, bulk_upload_type=KalturaNotImplemented, uploaded_by=KalturaNotImplemented, file_name=KalturaNotImplemented) kparams = {} kfiles = {} client.add_param(kparams, 'conversionProfileId', conversion_profile_id) client.add_param(kfiles, 'csvFileData', csv_file_data) client.add_param(kparams, 'bulkUploadType', bulk_upload_type) client.add_param(kparams, 'uploadedBy', uploaded_by) client.add_param(kparams, 'fileName', file_name) client.queue_service_action_call('bulkupload', 'add', 'KalturaBulkUpload', kparams, kfiles) if (client.is_multirequest) return nil end return client.do_queue() end # Get bulk upload batch job by id # @return [KalturaBulkUpload] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('bulkupload', 'get', 'KalturaBulkUpload', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List bulk upload batch jobs # @return [KalturaBulkUploadListResponse] def list(pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'pager', pager) client.queue_service_action_call('bulkupload', 'list', 'KalturaBulkUploadListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # serve action return the original file. # @return [file] def serve(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('bulkupload', 'serve', 'file', kparams) return client.get_serve_url() end # serveLog action return the original file. # @return [file] def serve_log(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('bulkupload', 'serveLog', 'file', kparams) return client.get_serve_url() end end # Add & Manage CategoryEntry - assign entry to category class KalturaCategoryEntryService < KalturaServiceBase def initialize(client) super(client) end # activate CategoryEntry when it is pending moderation # @return [] def activate(entry_id, category_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'categoryId', category_id) client.queue_service_action_call('categoryentry', 'activate', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Add new CategoryEntry # @return [KalturaCategoryEntry] def add(category_entry) kparams = {} client.add_param(kparams, 'categoryEntry', category_entry) client.queue_service_action_call('categoryentry', 'add', 'KalturaCategoryEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaBulkUpload] def add_from_bulk_upload(bulk_upload_data, bulk_upload_category_entry_data=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'bulkUploadData', bulk_upload_data) client.add_param(kparams, 'bulkUploadCategoryEntryData', bulk_upload_category_entry_data) client.queue_service_action_call('categoryentry', 'addFromBulkUpload', 'KalturaBulkUpload', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete CategoryEntry # @return [] def delete(entry_id, category_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'categoryId', category_id) client.queue_service_action_call('categoryentry', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Index CategoryEntry by Id # @return [int] def index(entry_id, category_id, should_update=true) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'categoryId', category_id) client.add_param(kparams, 'shouldUpdate', should_update) client.queue_service_action_call('categoryentry', 'index', 'int', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List all categoryEntry # @return [KalturaCategoryEntryListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('categoryentry', 'list', 'KalturaCategoryEntryListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # activate CategoryEntry when it is pending moderation # @return [] def reject(entry_id, category_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'categoryId', category_id) client.queue_service_action_call('categoryentry', 'reject', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # update privacy context from the category # @return [] def sync_privacy_context(entry_id, category_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'categoryId', category_id) client.queue_service_action_call('categoryentry', 'syncPrivacyContext', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaBulkUpload] def update_status_from_bulk(file_data, bulk_upload_data=KalturaNotImplemented, bulk_upload_category_entry_data=KalturaNotImplemented) kparams = {} kfiles = {} client.add_param(kfiles, 'fileData', file_data) client.add_param(kparams, 'bulkUploadData', bulk_upload_data) client.add_param(kparams, 'bulkUploadCategoryEntryData', bulk_upload_category_entry_data) client.queue_service_action_call('categoryentry', 'updateStatusFromBulk', 'KalturaBulkUpload', kparams, kfiles) if (client.is_multirequest) return nil end return client.do_queue() end end # Add & Manage Categories class KalturaCategoryService < KalturaServiceBase def initialize(client) super(client) end # Add new Category # @return [KalturaCategory] def add(category) kparams = {} client.add_param(kparams, 'category', category) client.queue_service_action_call('category', 'add', 'KalturaCategory', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaBulkUpload] def add_from_bulk_upload(file_data, bulk_upload_data=KalturaNotImplemented, bulk_upload_category_data=KalturaNotImplemented) kparams = {} kfiles = {} client.add_param(kfiles, 'fileData', file_data) client.add_param(kparams, 'bulkUploadData', bulk_upload_data) client.add_param(kparams, 'bulkUploadCategoryData', bulk_upload_category_data) client.queue_service_action_call('category', 'addFromBulkUpload', 'KalturaBulkUpload', kparams, kfiles) if (client.is_multirequest) return nil end return client.do_queue() end # Delete a Category # @return [] def delete(id, move_entries_to_parent_category=1) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'moveEntriesToParentCategory', move_entries_to_parent_category) client.queue_service_action_call('category', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get Category by id # @return [KalturaCategory] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('category', 'get', 'KalturaCategory', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Index Category by id # @return [int] def index(id, should_update=true) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'shouldUpdate', should_update) client.queue_service_action_call('category', 'index', 'int', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List all categories # @return [KalturaCategoryListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('category', 'list', 'KalturaCategoryListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Move categories that belong to the same parent category to a target categroy - enabled only for ks with disable entitlement # @return [bool] def move(category_ids, target_category_parent_id) kparams = {} client.add_param(kparams, 'categoryIds', category_ids) client.add_param(kparams, 'targetCategoryParentId', target_category_parent_id) client.queue_service_action_call('category', 'move', 'bool', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Unlock categories # @return [] def unlock_categories() kparams = {} client.queue_service_action_call('category', 'unlockCategories', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update Category # @return [KalturaCategory] def update(id, category) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'category', category) client.queue_service_action_call('category', 'update', 'KalturaCategory', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Add & Manage CategoryUser - membership of a user in a category class KalturaCategoryUserService < KalturaServiceBase def initialize(client) super(client) end # activate CategoryUser # @return [KalturaCategoryUser] def activate(category_id, user_id) kparams = {} client.add_param(kparams, 'categoryId', category_id) client.add_param(kparams, 'userId', user_id) client.queue_service_action_call('categoryuser', 'activate', 'KalturaCategoryUser', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Add new CategoryUser # @return [KalturaCategoryUser] def add(category_user) kparams = {} client.add_param(kparams, 'categoryUser', category_user) client.queue_service_action_call('categoryuser', 'add', 'KalturaCategoryUser', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaBulkUpload] def add_from_bulk_upload(file_data, bulk_upload_data=KalturaNotImplemented, bulk_upload_category_user_data=KalturaNotImplemented) kparams = {} kfiles = {} client.add_param(kfiles, 'fileData', file_data) client.add_param(kparams, 'bulkUploadData', bulk_upload_data) client.add_param(kparams, 'bulkUploadCategoryUserData', bulk_upload_category_user_data) client.queue_service_action_call('categoryuser', 'addFromBulkUpload', 'KalturaBulkUpload', kparams, kfiles) if (client.is_multirequest) return nil end return client.do_queue() end # Copy all member from parent category # @return [] def copy_from_category(category_id) kparams = {} client.add_param(kparams, 'categoryId', category_id) client.queue_service_action_call('categoryuser', 'copyFromCategory', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # reject CategoryUser # @return [KalturaCategoryUser] def deactivate(category_id, user_id) kparams = {} client.add_param(kparams, 'categoryId', category_id) client.add_param(kparams, 'userId', user_id) client.queue_service_action_call('categoryuser', 'deactivate', 'KalturaCategoryUser', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete a CategoryUser # @return [] def delete(category_id, user_id) kparams = {} client.add_param(kparams, 'categoryId', category_id) client.add_param(kparams, 'userId', user_id) client.queue_service_action_call('categoryuser', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get CategoryUser by id # @return [KalturaCategoryUser] def get(category_id, user_id) kparams = {} client.add_param(kparams, 'categoryId', category_id) client.add_param(kparams, 'userId', user_id) client.queue_service_action_call('categoryuser', 'get', 'KalturaCategoryUser', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Index CategoryUser by userid and category id # @return [int] def index(user_id, category_id, should_update=true) kparams = {} client.add_param(kparams, 'userId', user_id) client.add_param(kparams, 'categoryId', category_id) client.add_param(kparams, 'shouldUpdate', should_update) client.queue_service_action_call('categoryuser', 'index', 'int', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List all categories # @return [KalturaCategoryUserListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('categoryuser', 'list', 'KalturaCategoryUserListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update CategoryUser by id # @return [KalturaCategoryUser] def update(category_id, user_id, category_user, override=false) kparams = {} client.add_param(kparams, 'categoryId', category_id) client.add_param(kparams, 'userId', user_id) client.add_param(kparams, 'categoryUser', category_user) client.add_param(kparams, 'override', override) client.queue_service_action_call('categoryuser', 'update', 'KalturaCategoryUser', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Manage the connection between Conversion Profiles and Asset Params class KalturaConversionProfileAssetParamsService < KalturaServiceBase def initialize(client) super(client) end # Lists asset parmas of conversion profile by ID # @return [KalturaConversionProfileAssetParamsListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('conversionprofileassetparams', 'list', 'KalturaConversionProfileAssetParamsListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update asset parmas of conversion profile by ID # @return [KalturaConversionProfileAssetParams] def update(conversion_profile_id, asset_params_id, conversion_profile_asset_params) kparams = {} client.add_param(kparams, 'conversionProfileId', conversion_profile_id) client.add_param(kparams, 'assetParamsId', asset_params_id) client.add_param(kparams, 'conversionProfileAssetParams', conversion_profile_asset_params) client.queue_service_action_call('conversionprofileassetparams', 'update', 'KalturaConversionProfileAssetParams', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Add & Manage Conversion Profiles class KalturaConversionProfileService < KalturaServiceBase def initialize(client) super(client) end # Add new Conversion Profile # @return [KalturaConversionProfile] def add(conversion_profile) kparams = {} client.add_param(kparams, 'conversionProfile', conversion_profile) client.queue_service_action_call('conversionprofile', 'add', 'KalturaConversionProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete Conversion Profile by ID # @return [] def delete(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('conversionprofile', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get Conversion Profile by ID # @return [KalturaConversionProfile] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('conversionprofile', 'get', 'KalturaConversionProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get the partner's default conversion profile # @return [KalturaConversionProfile] def get_default(type=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'type', type) client.queue_service_action_call('conversionprofile', 'getDefault', 'KalturaConversionProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List Conversion Profiles by filter with paging support # @return [KalturaConversionProfileListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('conversionprofile', 'list', 'KalturaConversionProfileListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Set Conversion Profile to be the partner default # @return [KalturaConversionProfile] def set_as_default(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('conversionprofile', 'setAsDefault', 'KalturaConversionProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update Conversion Profile by ID # @return [KalturaConversionProfile] def update(id, conversion_profile) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'conversionProfile', conversion_profile) client.queue_service_action_call('conversionprofile', 'update', 'KalturaConversionProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Data service lets you manage data content (textual content) class KalturaDataService < KalturaServiceBase def initialize(client) super(client) end # Adds a new data entry # @return [KalturaDataEntry] def add(data_entry) kparams = {} client.add_param(kparams, 'dataEntry', data_entry) client.queue_service_action_call('data', 'add', 'KalturaDataEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update the dataContent of data entry using a resource # @return [string] def add_content(entry_id, resource) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'resource', resource) client.queue_service_action_call('data', 'addContent', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete a data entry. # @return [] def delete(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('data', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get data entry by ID. # @return [KalturaDataEntry] def get(entry_id, version=-1) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'version', version) client.queue_service_action_call('data', 'get', 'KalturaDataEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List data entries by filter with paging support. # @return [KalturaDataListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('data', 'list', 'KalturaDataListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # return the file from dataContent field. # @return [file] def serve(entry_id, version=-1, force_proxy=false) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'version', version) client.add_param(kparams, 'forceProxy', force_proxy) client.queue_service_action_call('data', 'serve', 'file', kparams) return client.get_serve_url() end # Update data entry. Only the properties that were set will be updated. # @return [KalturaDataEntry] def update(entry_id, document_entry) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'documentEntry', document_entry) client.queue_service_action_call('data', 'update', 'KalturaDataEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # delivery service is used to control delivery objects class KalturaDeliveryProfileService < KalturaServiceBase def initialize(client) super(client) end # Add new delivery. # @return [KalturaDeliveryProfile] def add(delivery) kparams = {} client.add_param(kparams, 'delivery', delivery) client.queue_service_action_call('deliveryprofile', 'add', 'KalturaDeliveryProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Add delivery based on existing delivery. # Must provide valid sourceDeliveryId # @return [KalturaDeliveryProfile] def clone(delivery_id) kparams = {} client.add_param(kparams, 'deliveryId', delivery_id) client.queue_service_action_call('deliveryprofile', 'clone', 'KalturaDeliveryProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get delivery by id # @return [KalturaDeliveryProfile] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('deliveryprofile', 'get', 'KalturaDeliveryProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieve a list of available delivery depends on the filter given # @return [KalturaDeliveryProfileListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('deliveryprofile', 'list', 'KalturaDeliveryProfileListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update existing delivery profile # @return [KalturaDeliveryProfile] def update(id, delivery) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'delivery', delivery) client.queue_service_action_call('deliveryprofile', 'update', 'KalturaDeliveryProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # EmailIngestionProfile service lets you manage email ingestion profile records class KalturaEmailIngestionProfileService < KalturaServiceBase def initialize(client) super(client) end # EmailIngestionProfile Add action allows you to add a EmailIngestionProfile to Kaltura DB # @return [KalturaEmailIngestionProfile] def add(email_ip) kparams = {} client.add_param(kparams, 'EmailIP', email_ip) client.queue_service_action_call('emailingestionprofile', 'add', 'KalturaEmailIngestionProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # add KalturaMediaEntry from email ingestion # @return [KalturaMediaEntry] def add_media_entry(media_entry, upload_token_id, email_prof_id, from_address, email_msg_id) kparams = {} client.add_param(kparams, 'mediaEntry', media_entry) client.add_param(kparams, 'uploadTokenId', upload_token_id) client.add_param(kparams, 'emailProfId', email_prof_id) client.add_param(kparams, 'fromAddress', from_address) client.add_param(kparams, 'emailMsgId', email_msg_id) client.queue_service_action_call('emailingestionprofile', 'addMediaEntry', 'KalturaMediaEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete an existing EmailIngestionProfile # @return [] def delete(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('emailingestionprofile', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieve a EmailIngestionProfile by id # @return [KalturaEmailIngestionProfile] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('emailingestionprofile', 'get', 'KalturaEmailIngestionProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieve a EmailIngestionProfile by email address # @return [KalturaEmailIngestionProfile] def get_by_email_address(email_address) kparams = {} client.add_param(kparams, 'emailAddress', email_address) client.queue_service_action_call('emailingestionprofile', 'getByEmailAddress', 'KalturaEmailIngestionProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update an existing EmailIngestionProfile # @return [KalturaEmailIngestionProfile] def update(id, email_ip) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'EmailIP', email_ip) client.queue_service_action_call('emailingestionprofile', 'update', 'KalturaEmailIngestionProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Base class for entry server node class KalturaEntryServerNodeService < KalturaServiceBase def initialize(client) super(client) end # @return [KalturaEntryServerNode] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('entryservernode', 'get', 'KalturaEntryServerNode', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaEntryServerNodeListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('entryservernode', 'list', 'KalturaEntryServerNodeListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaEntryServerNode] def update(id, entry_server_node) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'entryServerNode', entry_server_node) client.queue_service_action_call('entryservernode', 'update', 'KalturaEntryServerNode', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaEntryServerNode] def update_status(id, status) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'status', status) client.queue_service_action_call('entryservernode', 'updateStatus', 'KalturaEntryServerNode', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Validates server node still registered on entry # @return [] def validate_registered_entry_server_node(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('entryservernode', 'validateRegisteredEntryServerNode', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Export CSV service is used to manage CSV exports of objects class KalturaExportcsvService < KalturaServiceBase def initialize(client) super(client) end # Will serve a requested CSV # @return [string] def serve_csv(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('exportcsv', 'serveCsv', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Manage file assets class KalturaFileAssetService < KalturaServiceBase def initialize(client) super(client) end # Add new file asset # @return [KalturaFileAsset] def add(file_asset) kparams = {} client.add_param(kparams, 'fileAsset', file_asset) client.queue_service_action_call('fileasset', 'add', 'KalturaFileAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete file asset by id # @return [] def delete(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('fileasset', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get file asset by id # @return [KalturaFileAsset] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('fileasset', 'get', 'KalturaFileAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List file assets by filter and pager # @return [KalturaFileAssetListResponse] def list(filter, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('fileasset', 'list', 'KalturaFileAssetListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Serve file asset by id # @return [file] def serve(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('fileasset', 'serve', 'file', kparams) return client.get_serve_url() end # Set content of file asset # @return [KalturaFileAsset] def set_content(id, content_resource) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'contentResource', content_resource) client.queue_service_action_call('fileasset', 'setContent', 'KalturaFileAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update file asset by id # @return [KalturaFileAsset] def update(id, file_asset) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'fileAsset', file_asset) client.queue_service_action_call('fileasset', 'update', 'KalturaFileAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Retrieve information and invoke actions on Flavor Asset class KalturaFlavorAssetService < KalturaServiceBase def initialize(client) super(client) end # Add flavor asset # @return [KalturaFlavorAsset] def add(entry_id, flavor_asset) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'flavorAsset', flavor_asset) client.queue_service_action_call('flavorasset', 'add', 'KalturaFlavorAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Add and convert new Flavor Asset for Entry with specific Flavor Params # @return [] def convert(entry_id, flavor_params_id, priority=0) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'flavorParamsId', flavor_params_id) client.add_param(kparams, 'priority', priority) client.queue_service_action_call('flavorasset', 'convert', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete Flavor Asset by ID # @return [] def delete(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('flavorasset', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # delete all local file syncs for this asset # @return [] def delete_local_content(asset_id) kparams = {} client.add_param(kparams, 'assetId', asset_id) client.queue_service_action_call('flavorasset', 'deleteLocalContent', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # manually export an asset # @return [KalturaFlavorAsset] def export(asset_id, storage_profile_id) kparams = {} client.add_param(kparams, 'assetId', asset_id) client.add_param(kparams, 'storageProfileId', storage_profile_id) client.queue_service_action_call('flavorasset', 'export', 'KalturaFlavorAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get Flavor Asset by ID # @return [KalturaFlavorAsset] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('flavorasset', 'get', 'KalturaFlavorAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get Flavor Assets for Entry # @return [array] def get_by_entry_id(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('flavorasset', 'getByEntryId', 'KalturaFlavorAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get download URL for the Flavor Asset # @return [string] def get_download_url(id, use_cdn=false) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'useCdn', use_cdn) client.queue_service_action_call('flavorasset', 'getDownloadUrl', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get Flavor Asset with the relevant Flavor Params (Flavor Params can exist without Flavor Asset & vice versa) # @return [array] def get_flavor_assets_with_params(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('flavorasset', 'getFlavorAssetsWithParams', 'KalturaFlavorAssetWithParams', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get remote storage existing paths for the asset # @return [KalturaRemotePathListResponse] def get_remote_paths(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('flavorasset', 'getRemotePaths', 'KalturaRemotePathListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get download URL for the asset # @return [string] def get_url(id, storage_id=KalturaNotImplemented, force_proxy=false, options=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'storageId', storage_id) client.add_param(kparams, 'forceProxy', force_proxy) client.add_param(kparams, 'options', options) client.queue_service_action_call('flavorasset', 'getUrl', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get volume map by entry id # @return [file] def get_volume_map(flavor_id) kparams = {} client.add_param(kparams, 'flavorId', flavor_id) client.queue_service_action_call('flavorasset', 'getVolumeMap', 'file', kparams) return client.get_serve_url() end # Get web playable Flavor Assets for Entry # @return [array] def get_web_playable_by_entry_id(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('flavorasset', 'getWebPlayableByEntryId', 'KalturaFlavorAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List Flavor Assets by filter and pager # @return [KalturaFlavorAssetListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('flavorasset', 'list', 'KalturaFlavorAssetListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Reconvert Flavor Asset by ID # @return [] def reconvert(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('flavorasset', 'reconvert', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # serve cmd line to transcode the ad # @return [string] def serve_ad_stitch_cmd(asset_id, ffprobe_json=KalturaNotImplemented, duration=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'assetId', asset_id) client.add_param(kparams, 'ffprobeJson', ffprobe_json) client.add_param(kparams, 'duration', duration) client.queue_service_action_call('flavorasset', 'serveAdStitchCmd', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Set a given flavor as the original flavor # @return [] def set_as_source(asset_id) kparams = {} client.add_param(kparams, 'assetId', asset_id) client.queue_service_action_call('flavorasset', 'setAsSource', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update content of flavor asset # @return [KalturaFlavorAsset] def set_content(id, content_resource) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'contentResource', content_resource) client.queue_service_action_call('flavorasset', 'setContent', 'KalturaFlavorAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update flavor asset # @return [KalturaFlavorAsset] def update(id, flavor_asset) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'flavorAsset', flavor_asset) client.queue_service_action_call('flavorasset', 'update', 'KalturaFlavorAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Flavor Params Output service class KalturaFlavorParamsOutputService < KalturaServiceBase def initialize(client) super(client) end # Get flavor params output object by ID # @return [KalturaFlavorParamsOutput] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('flavorparamsoutput', 'get', 'KalturaFlavorParamsOutput', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List flavor params output objects by filter and pager # @return [KalturaFlavorParamsOutputListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('flavorparamsoutput', 'list', 'KalturaFlavorParamsOutputListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Add & Manage Flavor Params class KalturaFlavorParamsService < KalturaServiceBase def initialize(client) super(client) end # Add new Flavor Params # @return [KalturaFlavorParams] def add(flavor_params) kparams = {} client.add_param(kparams, 'flavorParams', flavor_params) client.queue_service_action_call('flavorparams', 'add', 'KalturaFlavorParams', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete Flavor Params by ID # @return [] def delete(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('flavorparams', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get Flavor Params by ID # @return [KalturaFlavorParams] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('flavorparams', 'get', 'KalturaFlavorParams', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get Flavor Params by Conversion Profile ID # @return [array] def get_by_conversion_profile_id(conversion_profile_id) kparams = {} client.add_param(kparams, 'conversionProfileId', conversion_profile_id) client.queue_service_action_call('flavorparams', 'getByConversionProfileId', 'KalturaFlavorParams', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List Flavor Params by filter with paging support (By default - all system default params will be listed too) # @return [KalturaFlavorParamsListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('flavorparams', 'list', 'KalturaFlavorParamsListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update Flavor Params by ID # @return [KalturaFlavorParams] def update(id, flavor_params) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'flavorParams', flavor_params) client.queue_service_action_call('flavorparams', 'update', 'KalturaFlavorParams', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Add & Manage GroupUser class KalturaGroupUserService < KalturaServiceBase def initialize(client) super(client) end # Add new GroupUser # @return [KalturaGroupUser] def add(group_user) kparams = {} client.add_param(kparams, 'groupUser', group_user) client.queue_service_action_call('groupuser', 'add', 'KalturaGroupUser', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # delete by userId and groupId # @return [] def delete(user_id, group_id) kparams = {} client.add_param(kparams, 'userId', user_id) client.add_param(kparams, 'groupId', group_id) client.queue_service_action_call('groupuser', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List all GroupUsers # @return [KalturaGroupUserListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('groupuser', 'list', 'KalturaGroupUserListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # sync by userId and groupIds # @return [KalturaBulkUpload] def sync(user_id, group_ids, remove_from_existing_groups=true, create_new_groups=true) kparams = {} client.add_param(kparams, 'userId', user_id) client.add_param(kparams, 'groupIds', group_ids) client.add_param(kparams, 'removeFromExistingGroups', remove_from_existing_groups) client.add_param(kparams, 'createNewGroups', create_new_groups) client.queue_service_action_call('groupuser', 'sync', 'KalturaBulkUpload', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # update GroupUser # @return [KalturaGroupUser] def update(group_user_id, group_user) kparams = {} client.add_param(kparams, 'groupUserId', group_user_id) client.add_param(kparams, 'groupUser', group_user) client.queue_service_action_call('groupuser', 'update', 'KalturaGroupUser', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Manage live channel segments class KalturaLiveChannelSegmentService < KalturaServiceBase def initialize(client) super(client) end # Add new live channel segment # @return [KalturaLiveChannelSegment] def add(live_channel_segment) kparams = {} client.add_param(kparams, 'liveChannelSegment', live_channel_segment) client.queue_service_action_call('livechannelsegment', 'add', 'KalturaLiveChannelSegment', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete live channel segment by id # @return [] def delete(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('livechannelsegment', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get live channel segment by id # @return [KalturaLiveChannelSegment] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('livechannelsegment', 'get', 'KalturaLiveChannelSegment', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List live channel segments by filter and pager # @return [KalturaLiveChannelSegmentListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('livechannelsegment', 'list', 'KalturaLiveChannelSegmentListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update live channel segment by id # @return [KalturaLiveChannelSegment] def update(id, live_channel_segment) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'liveChannelSegment', live_channel_segment) client.queue_service_action_call('livechannelsegment', 'update', 'KalturaLiveChannelSegment', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Live Channel service lets you manage live channels class KalturaLiveChannelService < KalturaServiceBase def initialize(client) super(client) end # Adds new live channel. # @return [KalturaLiveChannel] def add(live_channel) kparams = {} client.add_param(kparams, 'liveChannel', live_channel) client.queue_service_action_call('livechannel', 'add', 'KalturaLiveChannel', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Append recorded video to live entry # @return [KalturaLiveEntry] def append_recording(entry_id, asset_id, media_server_index, resource, duration, is_last_chunk=false) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'assetId', asset_id) client.add_param(kparams, 'mediaServerIndex', media_server_index) client.add_param(kparams, 'resource', resource) client.add_param(kparams, 'duration', duration) client.add_param(kparams, 'isLastChunk', is_last_chunk) client.queue_service_action_call('livechannel', 'appendRecording', 'KalturaLiveEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Create recorded entry id if it doesn't exist and make sure it happens on the DC that the live entry was created on. # @return [KalturaLiveEntry] def create_recorded_entry(entry_id, media_server_index, live_entry_status) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'mediaServerIndex', media_server_index) client.add_param(kparams, 'liveEntryStatus', live_entry_status) client.queue_service_action_call('livechannel', 'createRecordedEntry', 'KalturaLiveEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete a live channel. # @return [] def delete(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('livechannel', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get live channel by ID. # @return [KalturaLiveChannel] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('livechannel', 'get', 'KalturaLiveChannel', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delivering the status of a live channel (on-air/offline) # @return [bool] def is_live(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('livechannel', 'isLive', 'bool', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List live channels by filter with paging support. # @return [KalturaLiveChannelListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('livechannel', 'list', 'KalturaLiveChannelListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Register media server to live entry # @return [KalturaLiveEntry] def register_media_server(entry_id, hostname, media_server_index, application_name=KalturaNotImplemented, live_entry_status=1, should_create_recorded_entry=true) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'hostname', hostname) client.add_param(kparams, 'mediaServerIndex', media_server_index) client.add_param(kparams, 'applicationName', application_name) client.add_param(kparams, 'liveEntryStatus', live_entry_status) client.add_param(kparams, 'shouldCreateRecordedEntry', should_create_recorded_entry) client.queue_service_action_call('livechannel', 'registerMediaServer', 'KalturaLiveEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Set recorded video to live entry # @return [KalturaLiveEntry] def set_recorded_content(entry_id, media_server_index, resource, duration, recorded_entry_id=KalturaNotImplemented, flavor_params_id=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'mediaServerIndex', media_server_index) client.add_param(kparams, 'resource', resource) client.add_param(kparams, 'duration', duration) client.add_param(kparams, 'recordedEntryId', recorded_entry_id) client.add_param(kparams, 'flavorParamsId', flavor_params_id) client.queue_service_action_call('livechannel', 'setRecordedContent', 'KalturaLiveEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Unregister media server from live entry # @return [KalturaLiveEntry] def unregister_media_server(entry_id, hostname, media_server_index) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'hostname', hostname) client.add_param(kparams, 'mediaServerIndex', media_server_index) client.queue_service_action_call('livechannel', 'unregisterMediaServer', 'KalturaLiveEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update live channel. Only the properties that were set will be updated. # @return [KalturaLiveChannel] def update(id, live_channel) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'liveChannel', live_channel) client.queue_service_action_call('livechannel', 'update', 'KalturaLiveChannel', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Validates all registered media servers # @return [] def validate_registered_media_servers(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('livechannel', 'validateRegisteredMediaServers', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end class KalturaLiveReportsService < KalturaServiceBase def initialize(client) super(client) end # @return [KalturaLiveReportExportResponse] def export_to_csv(report_type, params) kparams = {} client.add_param(kparams, 'reportType', report_type) client.add_param(kparams, 'params', params) client.queue_service_action_call('livereports', 'exportToCsv', 'KalturaLiveReportExportResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [array] def get_events(report_type, filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'reportType', report_type) client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('livereports', 'getEvents', 'KalturaReportGraph', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaLiveStatsListResponse] def get_report(report_type, filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'reportType', report_type) client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('livereports', 'getReport', 'KalturaLiveStatsListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Will serve a requested report # @return [string] def serve_report(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('livereports', 'serveReport', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Stats Service class KalturaLiveStatsService < KalturaServiceBase def initialize(client) super(client) end # Will write to the event log a single line representing the event # KalturaStatsEvent $event # @return [bool] def collect(event) kparams = {} client.add_param(kparams, 'event', event) client.queue_service_action_call('livestats', 'collect', 'bool', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Live Stream service lets you manage live stream entries class KalturaLiveStreamService < KalturaServiceBase def initialize(client) super(client) end # Adds new live stream entry. # The entry will be queued for provision. # @return [KalturaLiveStreamEntry] def add(live_stream_entry, source_type=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'liveStreamEntry', live_stream_entry) client.add_param(kparams, 'sourceType', source_type) client.queue_service_action_call('livestream', 'add', 'KalturaLiveStreamEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Add new pushPublish configuration to entry # @return [KalturaLiveStreamEntry] def add_live_stream_push_publish_configuration(entry_id, protocol, url=KalturaNotImplemented, live_stream_configuration=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'protocol', protocol) client.add_param(kparams, 'url', url) client.add_param(kparams, 'liveStreamConfiguration', live_stream_configuration) client.queue_service_action_call('livestream', 'addLiveStreamPushPublishConfiguration', 'KalturaLiveStreamEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Append recorded video to live entry # @return [KalturaLiveEntry] def append_recording(entry_id, asset_id, media_server_index, resource, duration, is_last_chunk=false) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'assetId', asset_id) client.add_param(kparams, 'mediaServerIndex', media_server_index) client.add_param(kparams, 'resource', resource) client.add_param(kparams, 'duration', duration) client.add_param(kparams, 'isLastChunk', is_last_chunk) client.queue_service_action_call('livestream', 'appendRecording', 'KalturaLiveEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Authenticate live-stream entry against stream token and partner limitations # @return [KalturaLiveStreamEntry] def authenticate(entry_id, token, hostname=KalturaNotImplemented, media_server_index=KalturaNotImplemented, application_name=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'token', token) client.add_param(kparams, 'hostname', hostname) client.add_param(kparams, 'mediaServerIndex', media_server_index) client.add_param(kparams, 'applicationName', application_name) client.queue_service_action_call('livestream', 'authenticate', 'KalturaLiveStreamEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Creates periodic metadata sync-point events on a live stream # @return [] def create_periodic_sync_points(entry_id, interval, duration) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'interval', interval) client.add_param(kparams, 'duration', duration) client.queue_service_action_call('livestream', 'createPeriodicSyncPoints', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Create recorded entry id if it doesn't exist and make sure it happens on the DC that the live entry was created on. # @return [KalturaLiveEntry] def create_recorded_entry(entry_id, media_server_index, live_entry_status) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'mediaServerIndex', media_server_index) client.add_param(kparams, 'liveEntryStatus', live_entry_status) client.queue_service_action_call('livestream', 'createRecordedEntry', 'KalturaLiveEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete a live stream entry. # @return [] def delete(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('livestream', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get live stream entry by ID. # @return [KalturaLiveStreamEntry] def get(entry_id, version=-1) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'version', version) client.queue_service_action_call('livestream', 'get', 'KalturaLiveStreamEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delivering the status of a live stream (on-air/offline) if it is possible # @return [bool] def is_live(id, protocol) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'protocol', protocol) client.queue_service_action_call('livestream', 'isLive', 'bool', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List live stream entries by filter with paging support. # @return [KalturaLiveStreamListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('livestream', 'list', 'KalturaLiveStreamListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Regenerate new secure token for liveStream # @return [KalturaLiveEntry] def regenerate_stream_token(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('livestream', 'regenerateStreamToken', 'KalturaLiveEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Register media server to live entry # @return [KalturaLiveEntry] def register_media_server(entry_id, hostname, media_server_index, application_name=KalturaNotImplemented, live_entry_status=1, should_create_recorded_entry=true) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'hostname', hostname) client.add_param(kparams, 'mediaServerIndex', media_server_index) client.add_param(kparams, 'applicationName', application_name) client.add_param(kparams, 'liveEntryStatus', live_entry_status) client.add_param(kparams, 'shouldCreateRecordedEntry', should_create_recorded_entry) client.queue_service_action_call('livestream', 'registerMediaServer', 'KalturaLiveEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Remove push publish configuration from entry # @return [KalturaLiveStreamEntry] def remove_live_stream_push_publish_configuration(entry_id, protocol) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'protocol', protocol) client.queue_service_action_call('livestream', 'removeLiveStreamPushPublishConfiguration', 'KalturaLiveStreamEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Set recorded video to live entry # @return [KalturaLiveEntry] def set_recorded_content(entry_id, media_server_index, resource, duration, recorded_entry_id=KalturaNotImplemented, flavor_params_id=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'mediaServerIndex', media_server_index) client.add_param(kparams, 'resource', resource) client.add_param(kparams, 'duration', duration) client.add_param(kparams, 'recordedEntryId', recorded_entry_id) client.add_param(kparams, 'flavorParamsId', flavor_params_id) client.queue_service_action_call('livestream', 'setRecordedContent', 'KalturaLiveEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Unregister media server from live entry # @return [KalturaLiveEntry] def unregister_media_server(entry_id, hostname, media_server_index) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'hostname', hostname) client.add_param(kparams, 'mediaServerIndex', media_server_index) client.queue_service_action_call('livestream', 'unregisterMediaServer', 'KalturaLiveEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update live stream entry. Only the properties that were set will be updated. # @return [KalturaLiveStreamEntry] def update(entry_id, live_stream_entry) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'liveStreamEntry', live_stream_entry) client.queue_service_action_call('livestream', 'update', 'KalturaLiveStreamEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update entry thumbnail using url # @return [KalturaLiveStreamEntry] def update_offline_thumbnail_from_url(entry_id, url) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'url', url) client.queue_service_action_call('livestream', 'updateOfflineThumbnailFromUrl', 'KalturaLiveStreamEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update live stream entry thumbnail using a raw jpeg file # @return [KalturaLiveStreamEntry] def update_offline_thumbnail_jpeg(entry_id, file_data) kparams = {} kfiles = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kfiles, 'fileData', file_data) client.queue_service_action_call('livestream', 'updateOfflineThumbnailJpeg', 'KalturaLiveStreamEntry', kparams, kfiles) if (client.is_multirequest) return nil end return client.do_queue() end # Validates all registered media servers # @return [] def validate_registered_media_servers(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('livestream', 'validateRegisteredMediaServers', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Media Info service class KalturaMediaInfoService < KalturaServiceBase def initialize(client) super(client) end # List media info objects by filter and pager # @return [KalturaMediaInfoListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('mediainfo', 'list', 'KalturaMediaInfoListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Media service lets you upload and manage media files (images / videos & audio) class KalturaMediaService < KalturaServiceBase def initialize(client) super(client) end # Add entry # @return [KalturaMediaEntry] def add(entry) kparams = {} client.add_param(kparams, 'entry', entry) client.queue_service_action_call('media', 'add', 'KalturaMediaEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Add content to media entry which is not yet associated with content (therefore is in status NO_CONTENT). # If the requirement is to replace the entry's associated content, use action updateContent. # @return [KalturaMediaEntry] def add_content(entry_id, resource=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'resource', resource) client.queue_service_action_call('media', 'addContent', 'KalturaMediaEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Adds new media entry by importing an HTTP or FTP URL. # The entry will be queued for import and then for conversion. # This action should be exposed only to the batches # @return [KalturaMediaEntry] def add_from_bulk(media_entry, url, bulk_upload_id) kparams = {} client.add_param(kparams, 'mediaEntry', media_entry) client.add_param(kparams, 'url', url) client.add_param(kparams, 'bulkUploadId', bulk_upload_id) client.queue_service_action_call('media', 'addFromBulk', 'KalturaMediaEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Copy entry into new entry # @return [KalturaMediaEntry] def add_from_entry(source_entry_id, media_entry=KalturaNotImplemented, source_flavor_params_id=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'sourceEntryId', source_entry_id) client.add_param(kparams, 'mediaEntry', media_entry) client.add_param(kparams, 'sourceFlavorParamsId', source_flavor_params_id) client.queue_service_action_call('media', 'addFromEntry', 'KalturaMediaEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Copy flavor asset into new entry # @return [KalturaMediaEntry] def add_from_flavor_asset(source_flavor_asset_id, media_entry=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'sourceFlavorAssetId', source_flavor_asset_id) client.add_param(kparams, 'mediaEntry', media_entry) client.queue_service_action_call('media', 'addFromFlavorAsset', 'KalturaMediaEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Add new entry after the file was recorded on the server and the token id exists # @return [KalturaMediaEntry] def add_from_recorded_webcam(media_entry, webcam_token_id) kparams = {} client.add_param(kparams, 'mediaEntry', media_entry) client.add_param(kparams, 'webcamTokenId', webcam_token_id) client.queue_service_action_call('media', 'addFromRecordedWebcam', 'KalturaMediaEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Adds new media entry by importing the media file from a search provider. # This action should be used with the search service result. # @return [KalturaMediaEntry] def add_from_search_result(media_entry=KalturaNotImplemented, search_result=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'mediaEntry', media_entry) client.add_param(kparams, 'searchResult', search_result) client.queue_service_action_call('media', 'addFromSearchResult', 'KalturaMediaEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Add new entry after the specific media file was uploaded and the upload token id exists # @return [KalturaMediaEntry] def add_from_uploaded_file(media_entry, upload_token_id) kparams = {} client.add_param(kparams, 'mediaEntry', media_entry) client.add_param(kparams, 'uploadTokenId', upload_token_id) client.queue_service_action_call('media', 'addFromUploadedFile', 'KalturaMediaEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Adds new media entry by importing an HTTP or FTP URL. # The entry will be queued for import and then for conversion. # @return [KalturaMediaEntry] def add_from_url(media_entry, url) kparams = {} client.add_param(kparams, 'mediaEntry', media_entry) client.add_param(kparams, 'url', url) client.queue_service_action_call('media', 'addFromUrl', 'KalturaMediaEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Anonymously rank a media entry, no validation is done on duplicate rankings # @return [] def anonymous_rank(entry_id, rank) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'rank', rank) client.queue_service_action_call('media', 'anonymousRank', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Approve the media entry and mark the pending flags (if any) as moderated (this will make the entry playable) # @return [] def approve(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('media', 'approve', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Approves media replacement # @return [KalturaMediaEntry] def approve_replace(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('media', 'approveReplace', 'KalturaMediaEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Add new bulk upload batch job # Conversion profile id can be specified in the API or in the CSV file, the one in the CSV file will be stronger. # If no conversion profile was specified, partner's default will be used # @return [KalturaBulkUpload] def bulk_upload_add(file_data, bulk_upload_data=KalturaNotImplemented, bulk_upload_entry_data=KalturaNotImplemented) kparams = {} kfiles = {} client.add_param(kfiles, 'fileData', file_data) client.add_param(kparams, 'bulkUploadData', bulk_upload_data) client.add_param(kparams, 'bulkUploadEntryData', bulk_upload_entry_data) client.queue_service_action_call('media', 'bulkUploadAdd', 'KalturaBulkUpload', kparams, kfiles) if (client.is_multirequest) return nil end return client.do_queue() end # Cancels media replacement # @return [KalturaMediaEntry] def cancel_replace(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('media', 'cancelReplace', 'KalturaMediaEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Convert entry # @return [bigint] def convert(entry_id, conversion_profile_id=KalturaNotImplemented, dynamic_conversion_attributes=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'conversionProfileId', conversion_profile_id) client.add_param(kparams, 'dynamicConversionAttributes', dynamic_conversion_attributes) client.queue_service_action_call('media', 'convert', 'bigint', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Count media entries by filter. # @return [int] def count(filter=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.queue_service_action_call('media', 'count', 'int', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete a media entry. # @return [] def delete(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('media', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Creates a batch job that sends an email with a link to download a CSV containing a list of entries # @return [string] def export_to_csv(data) kparams = {} client.add_param(kparams, 'data', data) client.queue_service_action_call('media', 'exportToCsv', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Flag inappropriate media entry for moderation # @return [] def flag(moderation_flag) kparams = {} client.add_param(kparams, 'moderationFlag', moderation_flag) client.queue_service_action_call('media', 'flag', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get media entry by ID. # @return [KalturaMediaEntry] def get(entry_id, version=-1) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'version', version) client.queue_service_action_call('media', 'get', 'KalturaMediaEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get MRSS by entry id # XML will return as an escaped string # @return [string] def get_mrss(entry_id, extending_items_array=KalturaNotImplemented, features=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'extendingItemsArray', extending_items_array) client.add_param(kparams, 'features', features) client.queue_service_action_call('media', 'getMrss', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get volume map by entry id # @return [file] def get_volume_map(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('media', 'getVolumeMap', 'file', kparams) return client.get_serve_url() end # List media entries by filter with paging support. # @return [KalturaMediaListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('media', 'list', 'KalturaMediaListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List all pending flags for the media entry # @return [KalturaModerationFlagListResponse] def list_flags(entry_id, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('media', 'listFlags', 'KalturaModerationFlagListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Reject the media entry and mark the pending flags (if any) as moderated (this will make the entry non playable) # @return [] def reject(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('media', 'reject', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Request a new conversion job, this can be used to convert the media entry to a different format # @return [int] def request_conversion(entry_id, file_format) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'fileFormat', file_format) client.queue_service_action_call('media', 'requestConversion', 'int', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update media entry. Only the properties that were set will be updated. # @return [KalturaMediaEntry] def update(entry_id, media_entry) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'mediaEntry', media_entry) client.queue_service_action_call('media', 'update', 'KalturaMediaEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Replace content associated with the media entry. # @return [KalturaMediaEntry] def update_content(entry_id, resource, conversion_profile_id=KalturaNotImplemented, advanced_options=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'resource', resource) client.add_param(kparams, 'conversionProfileId', conversion_profile_id) client.add_param(kparams, 'advancedOptions', advanced_options) client.queue_service_action_call('media', 'updateContent', 'KalturaMediaEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update media entry thumbnail by a specified time offset (In seconds) # If flavor params id not specified, source flavor will be used by default # @return [KalturaMediaEntry] def update_thumbnail(entry_id, time_offset, flavor_params_id=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'timeOffset', time_offset) client.add_param(kparams, 'flavorParamsId', flavor_params_id) client.queue_service_action_call('media', 'updateThumbnail', 'KalturaMediaEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update media entry thumbnail from a different entry by a specified time offset (In seconds) # If flavor params id not specified, source flavor will be used by default # @return [KalturaMediaEntry] def update_thumbnail_from_source_entry(entry_id, source_entry_id, time_offset, flavor_params_id=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'sourceEntryId', source_entry_id) client.add_param(kparams, 'timeOffset', time_offset) client.add_param(kparams, 'flavorParamsId', flavor_params_id) client.queue_service_action_call('media', 'updateThumbnailFromSourceEntry', 'KalturaMediaEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update entry thumbnail using URL # @return [KalturaBaseEntry] def update_thumbnail_from_url(entry_id, url) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'url', url) client.queue_service_action_call('media', 'updateThumbnailFromUrl', 'KalturaBaseEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update media entry thumbnail using a raw jpeg file # @return [KalturaMediaEntry] def update_thumbnail_jpeg(entry_id, file_data) kparams = {} kfiles = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kfiles, 'fileData', file_data) client.queue_service_action_call('media', 'updateThumbnailJpeg', 'KalturaMediaEntry', kparams, kfiles) if (client.is_multirequest) return nil end return client.do_queue() end # Upload a media file to Kaltura, then the file can be used to create a media entry. # @return [string] def upload(file_data) kparams = {} kfiles = {} client.add_param(kfiles, 'fileData', file_data) client.queue_service_action_call('media', 'upload', 'string', kparams, kfiles) if (client.is_multirequest) return nil end return client.do_queue() end end # A Mix is an XML unique format invented by Kaltura, it allows the user to create a mix of videos and images, in and out points, transitions, text overlays, soundtrack, effects and much more... # Mixing service lets you create a new mix, manage its metadata and make basic manipulations. class KalturaMixingService < KalturaServiceBase def initialize(client) super(client) end # Adds a new mix. # If the dataContent is null, a default timeline will be created. # @return [KalturaMixEntry] def add(mix_entry) kparams = {} client.add_param(kparams, 'mixEntry', mix_entry) client.queue_service_action_call('mixing', 'add', 'KalturaMixEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Anonymously rank a mix entry, no validation is done on duplicate rankings # @return [] def anonymous_rank(entry_id, rank) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'rank', rank) client.queue_service_action_call('mixing', 'anonymousRank', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Appends a media entry to the end of the mix timeline, this will save the mix timeline as a new version. # @return [KalturaMixEntry] def append_media_entry(mix_entry_id, media_entry_id) kparams = {} client.add_param(kparams, 'mixEntryId', mix_entry_id) client.add_param(kparams, 'mediaEntryId', media_entry_id) client.queue_service_action_call('mixing', 'appendMediaEntry', 'KalturaMixEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Clones an existing mix. # @return [KalturaMixEntry] def clone(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('mixing', 'clone', 'KalturaMixEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Count mix entries by filter. # @return [int] def count(filter=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.queue_service_action_call('mixing', 'count', 'int', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete a mix entry. # @return [] def delete(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('mixing', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get mix entry by id. # @return [KalturaMixEntry] def get(entry_id, version=-1) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'version', version) client.queue_service_action_call('mixing', 'get', 'KalturaMixEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get the mixes in which the media entry is included # @return [array] def get_mixes_by_media_id(media_entry_id) kparams = {} client.add_param(kparams, 'mediaEntryId', media_entry_id) client.queue_service_action_call('mixing', 'getMixesByMediaId', 'KalturaMixEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get all ready media entries that exist in the given mix id # @return [array] def get_ready_media_entries(mix_id, version=-1) kparams = {} client.add_param(kparams, 'mixId', mix_id) client.add_param(kparams, 'version', version) client.queue_service_action_call('mixing', 'getReadyMediaEntries', 'KalturaMediaEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List entries by filter with paging support. # Return parameter is an array of mix entries. # @return [KalturaMixListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('mixing', 'list', 'KalturaMixListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update mix entry. Only the properties that were set will be updated. # @return [KalturaMixEntry] def update(entry_id, mix_entry) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'mixEntry', mix_entry) client.queue_service_action_call('mixing', 'update', 'KalturaMixEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Notification Service class KalturaNotificationService < KalturaServiceBase def initialize(client) super(client) end # Return the notifications for a specific entry id and type # @return [KalturaClientNotification] def get_client_notification(entry_id, type) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'type', type) client.queue_service_action_call('notification', 'getClientNotification', 'KalturaClientNotification', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # partner service allows you to change/manage your partner personal details and settings as well class KalturaPartnerService < KalturaServiceBase def initialize(client) super(client) end # Count partner's existing sub-publishers (count includes the partner itself). # @return [int] def count(filter=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.queue_service_action_call('partner', 'count', 'int', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieve partner object by Id # @return [KalturaPartner] def get(id=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('partner', 'get', 'KalturaPartner', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieve all info attributed to the partner # This action expects no parameters. It returns information for the current KS partnerId. # @return [KalturaPartner] def get_info() kparams = {} client.queue_service_action_call('partner', 'getInfo', 'KalturaPartner', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Returns partner public info by Id # @return [KalturaPartnerPublicInfo] def get_public_info(id=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('partner', 'getPublicInfo', 'KalturaPartnerPublicInfo', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieve partner secret and admin secret # @return [KalturaPartner] def get_secrets(partner_id, admin_email, cms_password, otp=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'partnerId', partner_id) client.add_param(kparams, 'adminEmail', admin_email) client.add_param(kparams, 'cmsPassword', cms_password) client.add_param(kparams, 'otp', otp) client.queue_service_action_call('partner', 'getSecrets', 'KalturaPartner', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get usage statistics for a partner # Calculation is done according to partner's package # @return [KalturaPartnerStatistics] def get_statistics() kparams = {} client.queue_service_action_call('partner', 'getStatistics', 'KalturaPartnerStatistics', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get usage statistics for a partner # Calculation is done according to partner's package # Additional data returned is a graph points of streaming usage in a time frame # The resolution can be "days" or "months" # @return [KalturaPartnerUsage] def get_usage(year='', month=1, resolution=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'year', year) client.add_param(kparams, 'month', month) client.add_param(kparams, 'resolution', resolution) client.queue_service_action_call('partner', 'getUsage', 'KalturaPartnerUsage', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List partners by filter with paging support # Current implementation will only list the sub partners of the partner initiating the API call (using the current KS). # This action is only partially implemented to support listing sub partners of a VAR partner. # @return [KalturaPartnerListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('partner', 'list', 'KalturaPartnerListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List partner's current processes' statuses # @return [KalturaFeatureStatusListResponse] def list_feature_status() kparams = {} client.queue_service_action_call('partner', 'listFeatureStatus', 'KalturaFeatureStatusListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieve a list of partner objects which the current user is allowed to access. # @return [KalturaPartnerListResponse] def list_partners_for_user(partner_filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'partnerFilter', partner_filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('partner', 'listPartnersForUser', 'KalturaPartnerListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Create a new Partner object # @return [KalturaPartner] def register(partner, cms_password='', template_partner_id=KalturaNotImplemented, silent=false) kparams = {} client.add_param(kparams, 'partner', partner) client.add_param(kparams, 'cmsPassword', cms_password) client.add_param(kparams, 'templatePartnerId', template_partner_id) client.add_param(kparams, 'silent', silent) client.queue_service_action_call('partner', 'register', 'KalturaPartner', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update details and settings of an existing partner # @return [KalturaPartner] def update(partner, allow_empty=false) kparams = {} client.add_param(kparams, 'partner', partner) client.add_param(kparams, 'allowEmpty', allow_empty) client.queue_service_action_call('partner', 'update', 'KalturaPartner', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # PermissionItem service lets you create and manage permission items class KalturaPermissionItemService < KalturaServiceBase def initialize(client) super(client) end # Adds a new permission item object to the account. # This action is available only to Kaltura system administrators. # @return [KalturaPermissionItem] def add(permission_item) kparams = {} client.add_param(kparams, 'permissionItem', permission_item) client.queue_service_action_call('permissionitem', 'add', 'KalturaPermissionItem', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Deletes an existing permission item object. # This action is available only to Kaltura system administrators. # @return [KalturaPermissionItem] def delete(permission_item_id) kparams = {} client.add_param(kparams, 'permissionItemId', permission_item_id) client.queue_service_action_call('permissionitem', 'delete', 'KalturaPermissionItem', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieves a permission item object using its ID. # @return [KalturaPermissionItem] def get(permission_item_id) kparams = {} client.add_param(kparams, 'permissionItemId', permission_item_id) client.queue_service_action_call('permissionitem', 'get', 'KalturaPermissionItem', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Lists permission item objects that are associated with an account. # @return [KalturaPermissionItemListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('permissionitem', 'list', 'KalturaPermissionItemListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Updates an existing permission item object. # This action is available only to Kaltura system administrators. # @return [KalturaPermissionItem] def update(permission_item_id, permission_item) kparams = {} client.add_param(kparams, 'permissionItemId', permission_item_id) client.add_param(kparams, 'permissionItem', permission_item) client.queue_service_action_call('permissionitem', 'update', 'KalturaPermissionItem', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Permission service lets you create and manage user permissions class KalturaPermissionService < KalturaServiceBase def initialize(client) super(client) end # Adds a new permission object to the account. # @return [KalturaPermission] def add(permission) kparams = {} client.add_param(kparams, 'permission', permission) client.queue_service_action_call('permission', 'add', 'KalturaPermission', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Deletes an existing permission object. # @return [KalturaPermission] def delete(permission_name) kparams = {} client.add_param(kparams, 'permissionName', permission_name) client.queue_service_action_call('permission', 'delete', 'KalturaPermission', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieves a permission object using its ID. # @return [KalturaPermission] def get(permission_name) kparams = {} client.add_param(kparams, 'permissionName', permission_name) client.queue_service_action_call('permission', 'get', 'KalturaPermission', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieves a list of permissions that apply to the current KS. # @return [string] def get_current_permissions() kparams = {} client.queue_service_action_call('permission', 'getCurrentPermissions', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Lists permission objects that are associated with an account. # Blocked permissions are listed unless you use a filter to exclude them. # Blocked permissions are listed unless you use a filter to exclude them. # @return [KalturaPermissionListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('permission', 'list', 'KalturaPermissionListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Updates an existing permission object. # @return [KalturaPermission] def update(permission_name, permission) kparams = {} client.add_param(kparams, 'permissionName', permission_name) client.add_param(kparams, 'permission', permission) client.queue_service_action_call('permission', 'update', 'KalturaPermission', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Playlist service lets you create,manage and play your playlists # Playlists could be static (containing a fixed list of entries) or dynamic (based on a filter) class KalturaPlaylistService < KalturaServiceBase def initialize(client) super(client) end # Add new playlist # Note that all entries used in a playlist will become public and may appear in KalturaNetwork # @return [KalturaPlaylist] def add(playlist, update_stats=false) kparams = {} client.add_param(kparams, 'playlist', playlist) client.add_param(kparams, 'updateStats', update_stats) client.queue_service_action_call('playlist', 'add', 'KalturaPlaylist', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Clone an existing playlist # @return [KalturaPlaylist] def clone(id, new_playlist=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'newPlaylist', new_playlist) client.queue_service_action_call('playlist', 'clone', 'KalturaPlaylist', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete existing playlist # @return [] def delete(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('playlist', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieve playlist for playing purpose # @return [array] def execute(id, detailed='', playlist_context=KalturaNotImplemented, filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'detailed', detailed) client.add_param(kparams, 'playlistContext', playlist_context) client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('playlist', 'execute', 'KalturaBaseEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieve playlist for playing purpose, based on content # @return [array] def execute_from_content(playlist_type, playlist_content, detailed='', pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'playlistType', playlist_type) client.add_param(kparams, 'playlistContent', playlist_content) client.add_param(kparams, 'detailed', detailed) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('playlist', 'executeFromContent', 'KalturaBaseEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieve playlist for playing purpose, based on media entry filters # @return [array] def execute_from_filters(filters, total_results, detailed='1', pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filters', filters) client.add_param(kparams, 'totalResults', total_results) client.add_param(kparams, 'detailed', detailed) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('playlist', 'executeFromFilters', 'KalturaBaseEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieve a playlist # @return [KalturaPlaylist] def get(id, version=-1) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'version', version) client.queue_service_action_call('playlist', 'get', 'KalturaPlaylist', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieve playlist statistics # @return [KalturaPlaylist] def get_stats_from_content(playlist_type, playlist_content) kparams = {} client.add_param(kparams, 'playlistType', playlist_type) client.add_param(kparams, 'playlistContent', playlist_content) client.queue_service_action_call('playlist', 'getStatsFromContent', 'KalturaPlaylist', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List available playlists # @return [KalturaPlaylistListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('playlist', 'list', 'KalturaPlaylistListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update existing playlist # Note - you cannot change playlist type. Updated playlist must be of the same type. # @return [KalturaPlaylist] def update(id, playlist, update_stats=false) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'playlist', playlist) client.add_param(kparams, 'updateStats', update_stats) client.queue_service_action_call('playlist', 'update', 'KalturaPlaylist', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # api for getting reports data by the report type and some inputFilter class KalturaReportService < KalturaServiceBase def initialize(client) super(client) end # @return [KalturaReportResponse] def execute(id, params=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'params', params) client.queue_service_action_call('report', 'execute', 'KalturaReportResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaReportExportResponse] def export_to_csv(params) kparams = {} client.add_param(kparams, 'params', params) client.queue_service_action_call('report', 'exportToCsv', 'KalturaReportExportResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # report getBaseTotal action allows to get the total base for storage reports # @return [array] def get_base_total(report_type, report_input_filter, object_ids=KalturaNotImplemented, response_options=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'reportType', report_type) client.add_param(kparams, 'reportInputFilter', report_input_filter) client.add_param(kparams, 'objectIds', object_ids) client.add_param(kparams, 'responseOptions', response_options) client.queue_service_action_call('report', 'getBaseTotal', 'KalturaReportBaseTotal', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [file] def get_csv(id, params=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'params', params) client.queue_service_action_call('report', 'getCsv', 'file', kparams) return client.get_serve_url() end # Returns report CSV file executed by string params with the following convention: param1=value1;param2=value2 # @return [file] def get_csv_from_string_params(id, params=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'params', params) client.queue_service_action_call('report', 'getCsvFromStringParams', 'file', kparams) return client.get_serve_url() end # report getGraphs action allows to get a graph data for a specific report. # @return [array] def get_graphs(report_type, report_input_filter, dimension=KalturaNotImplemented, object_ids=KalturaNotImplemented, response_options=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'reportType', report_type) client.add_param(kparams, 'reportInputFilter', report_input_filter) client.add_param(kparams, 'dimension', dimension) client.add_param(kparams, 'objectIds', object_ids) client.add_param(kparams, 'responseOptions', response_options) client.queue_service_action_call('report', 'getGraphs', 'KalturaReportGraph', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # report getTable action allows to get a graph data for a specific report. # @return [KalturaReportTable] def get_table(report_type, report_input_filter, pager, order=KalturaNotImplemented, object_ids=KalturaNotImplemented, response_options=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'reportType', report_type) client.add_param(kparams, 'reportInputFilter', report_input_filter) client.add_param(kparams, 'pager', pager) client.add_param(kparams, 'order', order) client.add_param(kparams, 'objectIds', object_ids) client.add_param(kparams, 'responseOptions', response_options) client.queue_service_action_call('report', 'getTable', 'KalturaReportTable', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # report getTotal action allows to get a graph data for a specific report. # @return [KalturaReportTotal] def get_total(report_type, report_input_filter, object_ids=KalturaNotImplemented, response_options=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'reportType', report_type) client.add_param(kparams, 'reportInputFilter', report_input_filter) client.add_param(kparams, 'objectIds', object_ids) client.add_param(kparams, 'responseOptions', response_options) client.queue_service_action_call('report', 'getTotal', 'KalturaReportTotal', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # will create a CSV file for the given report and return the URL to access it # @return [string] def get_url_for_report_as_csv(report_title, report_text, headers, report_type, report_input_filter, dimension=KalturaNotImplemented, pager=KalturaNotImplemented, order=KalturaNotImplemented, object_ids=KalturaNotImplemented, response_options=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'reportTitle', report_title) client.add_param(kparams, 'reportText', report_text) client.add_param(kparams, 'headers', headers) client.add_param(kparams, 'reportType', report_type) client.add_param(kparams, 'reportInputFilter', report_input_filter) client.add_param(kparams, 'dimension', dimension) client.add_param(kparams, 'pager', pager) client.add_param(kparams, 'order', order) client.add_param(kparams, 'objectIds', object_ids) client.add_param(kparams, 'responseOptions', response_options) client.queue_service_action_call('report', 'getUrlForReportAsCsv', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Will serve a requested report # @return [string] def serve(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('report', 'serve', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Manage response profiles class KalturaResponseProfileService < KalturaServiceBase def initialize(client) super(client) end # Add new response profile # @return [KalturaResponseProfile] def add(add_response_profile) kparams = {} client.add_param(kparams, 'addResponseProfile', add_response_profile) client.queue_service_action_call('responseprofile', 'add', 'KalturaResponseProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Clone an existing response profile # @return [KalturaResponseProfile] def clone(id, profile) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'profile', profile) client.queue_service_action_call('responseprofile', 'clone', 'KalturaResponseProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete response profile by id # @return [] def delete(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('responseprofile', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get response profile by id # @return [KalturaResponseProfile] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('responseprofile', 'get', 'KalturaResponseProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List response profiles by filter and pager # @return [KalturaResponseProfileListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('responseprofile', 'list', 'KalturaResponseProfileListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Recalculate response profile cached objects # @return [KalturaResponseProfileCacheRecalculateResults] def recalculate(options) kparams = {} client.add_param(kparams, 'options', options) client.queue_service_action_call('responseprofile', 'recalculate', 'KalturaResponseProfileCacheRecalculateResults', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update response profile by id # @return [KalturaResponseProfile] def update(id, update_response_profile) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'updateResponseProfile', update_response_profile) client.queue_service_action_call('responseprofile', 'update', 'KalturaResponseProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update response profile status by id # @return [KalturaResponseProfile] def update_status(id, status) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'status', status) client.queue_service_action_call('responseprofile', 'updateStatus', 'KalturaResponseProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Expose the schema definitions for syndication MRSS, bulk upload XML and other schema types. class KalturaSchemaService < KalturaServiceBase def initialize(client) super(client) end # Serves the requested XSD according to the type and name. # @return [file] def serve(type) kparams = {} client.add_param(kparams, 'type', type) client.queue_service_action_call('schema', 'serve', 'file', kparams) return client.get_serve_url() end end # Search service allows you to search for media in various media providers # This service is being used mostly by the CW component class KalturaSearchService < KalturaServiceBase def initialize(client) super(client) end # @return [KalturaSearchAuthData] def external_login(search_source, user_name, password) kparams = {} client.add_param(kparams, 'searchSource', search_source) client.add_param(kparams, 'userName', user_name) client.add_param(kparams, 'password', password) client.queue_service_action_call('search', 'externalLogin', 'KalturaSearchAuthData', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieve extra information about media found in search action # Some providers return only part of the fields needed to create entry from, use this action to get the rest of the fields. # @return [KalturaSearchResult] def get_media_info(search_result) kparams = {} client.add_param(kparams, 'searchResult', search_result) client.queue_service_action_call('search', 'getMediaInfo', 'KalturaSearchResult', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Search for media in one of the supported media providers # @return [KalturaSearchResultResponse] def search(search, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'search', search) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('search', 'search', 'KalturaSearchResultResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Search for media given a specific URL # Kaltura supports a searchURL action on some of the media providers. # This action will return a KalturaSearchResult object based on a given URL (assuming the media provider is supported) # @return [KalturaSearchResult] def search_url(media_type, url) kparams = {} client.add_param(kparams, 'mediaType', media_type) client.add_param(kparams, 'url', url) client.queue_service_action_call('search', 'searchUrl', 'KalturaSearchResult', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Server Node service class KalturaServerNodeService < KalturaServiceBase def initialize(client) super(client) end # Adds a server node to the Kaltura DB. # @return [KalturaServerNode] def add(server_node) kparams = {} client.add_param(kparams, 'serverNode', server_node) client.queue_service_action_call('servernode', 'add', 'KalturaServerNode', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # delete server node by id # @return [] def delete(server_node_id) kparams = {} client.add_param(kparams, 'serverNodeId', server_node_id) client.queue_service_action_call('servernode', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Disable server node by id # @return [KalturaServerNode] def disable(server_node_id) kparams = {} client.add_param(kparams, 'serverNodeId', server_node_id) client.queue_service_action_call('servernode', 'disable', 'KalturaServerNode', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Enable server node by id # @return [KalturaServerNode] def enable(server_node_id) kparams = {} client.add_param(kparams, 'serverNodeId', server_node_id) client.queue_service_action_call('servernode', 'enable', 'KalturaServerNode', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get server node by id # @return [KalturaServerNode] def get(server_node_id) kparams = {} client.add_param(kparams, 'serverNodeId', server_node_id) client.queue_service_action_call('servernode', 'get', 'KalturaServerNode', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get the edge server node full path # @return [string] def get_full_path(host_name, protocol='http', delivery_format=KalturaNotImplemented, delivery_type=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'hostName', host_name) client.add_param(kparams, 'protocol', protocol) client.add_param(kparams, 'deliveryFormat', delivery_format) client.add_param(kparams, 'deliveryType', delivery_type) client.queue_service_action_call('servernode', 'getFullPath', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaServerNodeListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('servernode', 'list', 'KalturaServerNodeListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Mark server node offline # @return [KalturaServerNode] def mark_offline(server_node_id) kparams = {} client.add_param(kparams, 'serverNodeId', server_node_id) client.queue_service_action_call('servernode', 'markOffline', 'KalturaServerNode', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update server node status # @return [KalturaServerNode] def report_status(host_name, server_node=KalturaNotImplemented, server_node_status=1) kparams = {} client.add_param(kparams, 'hostName', host_name) client.add_param(kparams, 'serverNode', server_node) client.add_param(kparams, 'serverNodeStatus', server_node_status) client.queue_service_action_call('servernode', 'reportStatus', 'KalturaServerNode', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update server node by id # @return [KalturaServerNode] def update(server_node_id, server_node) kparams = {} client.add_param(kparams, 'serverNodeId', server_node_id) client.add_param(kparams, 'serverNode', server_node) client.queue_service_action_call('servernode', 'update', 'KalturaServerNode', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Session service class KalturaSessionService < KalturaServiceBase def initialize(client) super(client) end # End a session with the Kaltura server, making the current KS invalid. # @return [] def end() kparams = {} client.queue_service_action_call('session', 'end', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Parse session key and return its info # @return [KalturaSessionInfo] def get(session=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'session', session) client.queue_service_action_call('session', 'get', 'KalturaSessionInfo', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Start an impersonated session with Kaltura's server. # The result KS is the session key that you should pass to all services that requires a ticket. # @return [string] def impersonate(secret, impersonated_partner_id, user_id='', type=0, partner_id=KalturaNotImplemented, expiry=86400, privileges=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'secret', secret) client.add_param(kparams, 'impersonatedPartnerId', impersonated_partner_id) client.add_param(kparams, 'userId', user_id) client.add_param(kparams, 'type', type) client.add_param(kparams, 'partnerId', partner_id) client.add_param(kparams, 'expiry', expiry) client.add_param(kparams, 'privileges', privileges) client.queue_service_action_call('session', 'impersonate', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Start an impersonated session with Kaltura's server. # The result KS info contains the session key that you should pass to all services that requires a ticket. # Type, expiry and privileges won't be changed if they're not set # @return [KalturaSessionInfo] def impersonate_by_ks(session, type=KalturaNotImplemented, expiry=KalturaNotImplemented, privileges=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'session', session) client.add_param(kparams, 'type', type) client.add_param(kparams, 'expiry', expiry) client.add_param(kparams, 'privileges', privileges) client.queue_service_action_call('session', 'impersonateByKs', 'KalturaSessionInfo', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Start a session with Kaltura's server. # The result KS is the session key that you should pass to all services that requires a ticket. # @return [string] def start(secret, user_id='', type=0, partner_id=KalturaNotImplemented, expiry=86400, privileges=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'secret', secret) client.add_param(kparams, 'userId', user_id) client.add_param(kparams, 'type', type) client.add_param(kparams, 'partnerId', partner_id) client.add_param(kparams, 'expiry', expiry) client.add_param(kparams, 'privileges', privileges) client.queue_service_action_call('session', 'start', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Start a session for Kaltura's flash widgets # @return [KalturaStartWidgetSessionResponse] def start_widget_session(widget_id, expiry=86400) kparams = {} client.add_param(kparams, 'widgetId', widget_id) client.add_param(kparams, 'expiry', expiry) client.queue_service_action_call('session', 'startWidgetSession', 'KalturaStartWidgetSessionResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Stats Service class KalturaStatsService < KalturaServiceBase def initialize(client) super(client) end # Will write to the event log a single line representing the event # client version - will help interprete the line structure. different client versions might have slightly different data/data formats in the line # event_id - number is the row number in yuval's excel # datetime - same format as MySql's datetime - can change and should reflect the time zone # session id - can be some big random number or guid # partner id # entry id # unique viewer # widget id # ui_conf id # uid - the puser id as set by the ppartner # current point - in milliseconds # duration - milliseconds # user ip # process duration - in milliseconds # control id # seek # new point # referrer # # # KalturaStatsEvent $event # @return [bool] def collect(event) kparams = {} client.add_param(kparams, 'event', event) client.queue_service_action_call('stats', 'collect', 'bool', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Will collect the kmcEvent sent form the KMC client # // this will actually be an empty function because all events will be sent using GET and will anyway be logged in the apache log # @return [] def kmc_collect(kmc_event) kparams = {} client.add_param(kparams, 'kmcEvent', kmc_event) client.queue_service_action_call('stats', 'kmcCollect', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Use this action to report device capabilities to the kaltura server. # @return [] def report_device_capabilities(data) kparams = {} client.add_param(kparams, 'data', data) client.queue_service_action_call('stats', 'reportDeviceCapabilities', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Use this action to report errors to the kaltura server. # @return [] def report_error(error_code, error_message) kparams = {} client.add_param(kparams, 'errorCode', error_code) client.add_param(kparams, 'errorMessage', error_message) client.queue_service_action_call('stats', 'reportError', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaCEError] def report_kce_error(kaltura_ce_error) kparams = {} client.add_param(kparams, 'kalturaCEError', kaltura_ce_error) client.queue_service_action_call('stats', 'reportKceError', 'KalturaCEError', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # The Storage Profile service allows you to export your Kaltura content to external storage volumes. # This service is disabled by default, please contact your account manager if you wish to enable it for your partner. class KalturaStorageProfileService < KalturaServiceBase def initialize(client) super(client) end # Adds a storage profile to the Kaltura DB. # @return [KalturaStorageProfile] def add(storage_profile) kparams = {} client.add_param(kparams, 'storageProfile', storage_profile) client.queue_service_action_call('storageprofile', 'add', 'KalturaStorageProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get storage profile by id # @return [KalturaStorageProfile] def get(storage_profile_id) kparams = {} client.add_param(kparams, 'storageProfileId', storage_profile_id) client.queue_service_action_call('storageprofile', 'get', 'KalturaStorageProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaStorageProfileListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('storageprofile', 'list', 'KalturaStorageProfileListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update storage profile by id # @return [KalturaStorageProfile] def update(storage_profile_id, storage_profile) kparams = {} client.add_param(kparams, 'storageProfileId', storage_profile_id) client.add_param(kparams, 'storageProfile', storage_profile) client.queue_service_action_call('storageprofile', 'update', 'KalturaStorageProfile', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [] def update_status(storage_id, status) kparams = {} client.add_param(kparams, 'storageId', storage_id) client.add_param(kparams, 'status', status) client.queue_service_action_call('storageprofile', 'updateStatus', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Add & Manage Syndication Feeds class KalturaSyndicationFeedService < KalturaServiceBase def initialize(client) super(client) end # Add new Syndication Feed # @return [KalturaBaseSyndicationFeed] def add(syndication_feed) kparams = {} client.add_param(kparams, 'syndicationFeed', syndication_feed) client.queue_service_action_call('syndicationfeed', 'add', 'KalturaBaseSyndicationFeed', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete Syndication Feed by ID # @return [] def delete(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('syndicationfeed', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get Syndication Feed by ID # @return [KalturaBaseSyndicationFeed] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('syndicationfeed', 'get', 'KalturaBaseSyndicationFeed', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # get entry count for a syndication feed # @return [KalturaSyndicationFeedEntryCount] def get_entry_count(feed_id) kparams = {} client.add_param(kparams, 'feedId', feed_id) client.queue_service_action_call('syndicationfeed', 'getEntryCount', 'KalturaSyndicationFeedEntryCount', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List Syndication Feeds by filter with paging support # @return [KalturaBaseSyndicationFeedListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('syndicationfeed', 'list', 'KalturaBaseSyndicationFeedListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # request conversion for all entries that doesn't have the required flavor param # returns a comma-separated ids of conversion jobs # @return [string] def request_conversion(feed_id) kparams = {} client.add_param(kparams, 'feedId', feed_id) client.queue_service_action_call('syndicationfeed', 'requestConversion', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update Syndication Feed by ID # @return [KalturaBaseSyndicationFeed] def update(id, syndication_feed) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'syndicationFeed', syndication_feed) client.queue_service_action_call('syndicationfeed', 'update', 'KalturaBaseSyndicationFeed', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # System service is used for internal system helpers & to retrieve system level information class KalturaSystemService < KalturaServiceBase def initialize(client) super(client) end # @return [string] def get_health_check() kparams = {} client.queue_service_action_call('system', 'getHealthCheck', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [int] def get_time() kparams = {} client.queue_service_action_call('system', 'getTime', 'int', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [string] def get_version() kparams = {} client.queue_service_action_call('system', 'getVersion', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [bool] def ping() kparams = {} client.queue_service_action_call('system', 'ping', 'bool', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [bool] def ping_database() kparams = {} client.queue_service_action_call('system', 'pingDatabase', 'bool', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Retrieve information and invoke actions on Thumb Asset class KalturaThumbAssetService < KalturaServiceBase def initialize(client) super(client) end # Add thumbnail asset # @return [KalturaThumbAsset] def add(entry_id, thumb_asset) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'thumbAsset', thumb_asset) client.queue_service_action_call('thumbasset', 'add', 'KalturaThumbAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaThumbAsset] def add_from_image(entry_id, file_data) kparams = {} kfiles = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kfiles, 'fileData', file_data) client.queue_service_action_call('thumbasset', 'addFromImage', 'KalturaThumbAsset', kparams, kfiles) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaThumbAsset] def add_from_url(entry_id, url) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'url', url) client.queue_service_action_call('thumbasset', 'addFromUrl', 'KalturaThumbAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [] def delete(thumb_asset_id) kparams = {} client.add_param(kparams, 'thumbAssetId', thumb_asset_id) client.queue_service_action_call('thumbasset', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # manually export an asset # @return [KalturaFlavorAsset] def export(asset_id, storage_profile_id) kparams = {} client.add_param(kparams, 'assetId', asset_id) client.add_param(kparams, 'storageProfileId', storage_profile_id) client.queue_service_action_call('thumbasset', 'export', 'KalturaFlavorAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaThumbAsset] def generate(entry_id, thumb_params, source_asset_id=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'thumbParams', thumb_params) client.add_param(kparams, 'sourceAssetId', source_asset_id) client.queue_service_action_call('thumbasset', 'generate', 'KalturaThumbAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaThumbAsset] def generate_by_entry_id(entry_id, dest_thumb_params_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'destThumbParamsId', dest_thumb_params_id) client.queue_service_action_call('thumbasset', 'generateByEntryId', 'KalturaThumbAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaThumbAsset] def get(thumb_asset_id) kparams = {} client.add_param(kparams, 'thumbAssetId', thumb_asset_id) client.queue_service_action_call('thumbasset', 'get', 'KalturaThumbAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [array] def get_by_entry_id(entry_id) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.queue_service_action_call('thumbasset', 'getByEntryId', 'KalturaThumbAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get remote storage existing paths for the asset # @return [KalturaRemotePathListResponse] def get_remote_paths(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('thumbasset', 'getRemotePaths', 'KalturaRemotePathListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get download URL for the asset # @return [string] def get_url(id, storage_id=KalturaNotImplemented, thumb_params=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'storageId', storage_id) client.add_param(kparams, 'thumbParams', thumb_params) client.queue_service_action_call('thumbasset', 'getUrl', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List Thumbnail Assets by filter and pager # @return [KalturaThumbAssetListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('thumbasset', 'list', 'KalturaThumbAssetListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaThumbAsset] def regenerate(thumb_asset_id) kparams = {} client.add_param(kparams, 'thumbAssetId', thumb_asset_id) client.queue_service_action_call('thumbasset', 'regenerate', 'KalturaThumbAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Serves thumbnail by its id # @return [file] def serve(thumb_asset_id, version=KalturaNotImplemented, thumb_params=KalturaNotImplemented, options=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'thumbAssetId', thumb_asset_id) client.add_param(kparams, 'version', version) client.add_param(kparams, 'thumbParams', thumb_params) client.add_param(kparams, 'options', options) client.queue_service_action_call('thumbasset', 'serve', 'file', kparams) return client.get_serve_url() end # Serves thumbnail by entry id and thumnail params id # @return [file] def serve_by_entry_id(entry_id, thumb_param_id=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'entryId', entry_id) client.add_param(kparams, 'thumbParamId', thumb_param_id) client.queue_service_action_call('thumbasset', 'serveByEntryId', 'file', kparams) return client.get_serve_url() end # Tags the thumbnail as DEFAULT_THUMB and removes that tag from all other thumbnail assets of the entry. # Create a new file sync link on the entry thumbnail that points to the thumbnail asset file sync. # @return [] def set_as_default(thumb_asset_id) kparams = {} client.add_param(kparams, 'thumbAssetId', thumb_asset_id) client.queue_service_action_call('thumbasset', 'setAsDefault', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update content of thumbnail asset # @return [KalturaThumbAsset] def set_content(id, content_resource) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'contentResource', content_resource) client.queue_service_action_call('thumbasset', 'setContent', 'KalturaThumbAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update thumbnail asset # @return [KalturaThumbAsset] def update(id, thumb_asset) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'thumbAsset', thumb_asset) client.queue_service_action_call('thumbasset', 'update', 'KalturaThumbAsset', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Thumbnail Params Output service class KalturaThumbParamsOutputService < KalturaServiceBase def initialize(client) super(client) end # Get thumb params output object by ID # @return [KalturaThumbParamsOutput] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('thumbparamsoutput', 'get', 'KalturaThumbParamsOutput', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List thumb params output objects by filter and pager # @return [KalturaThumbParamsOutputListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('thumbparamsoutput', 'list', 'KalturaThumbParamsOutputListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Add & Manage Thumb Params class KalturaThumbParamsService < KalturaServiceBase def initialize(client) super(client) end # Add new Thumb Params # @return [KalturaThumbParams] def add(thumb_params) kparams = {} client.add_param(kparams, 'thumbParams', thumb_params) client.queue_service_action_call('thumbparams', 'add', 'KalturaThumbParams', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete Thumb Params by ID # @return [] def delete(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('thumbparams', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get Thumb Params by ID # @return [KalturaThumbParams] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('thumbparams', 'get', 'KalturaThumbParams', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get Thumb Params by Conversion Profile ID # @return [array] def get_by_conversion_profile_id(conversion_profile_id) kparams = {} client.add_param(kparams, 'conversionProfileId', conversion_profile_id) client.queue_service_action_call('thumbparams', 'getByConversionProfileId', 'KalturaThumbParams', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List Thumb Params by filter with paging support (By default - all system default params will be listed too) # @return [KalturaThumbParamsListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('thumbparams', 'list', 'KalturaThumbParamsListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update Thumb Params by ID # @return [KalturaThumbParams] def update(id, thumb_params) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'thumbParams', thumb_params) client.queue_service_action_call('thumbparams', 'update', 'KalturaThumbParams', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # UiConf service lets you create and manage your UIConfs for the various flash components # This service is used by the KMC-ApplicationStudio class KalturaUiConfService < KalturaServiceBase def initialize(client) super(client) end # UIConf Add action allows you to add a UIConf to Kaltura DB # @return [KalturaUiConf] def add(ui_conf) kparams = {} client.add_param(kparams, 'uiConf', ui_conf) client.queue_service_action_call('uiconf', 'add', 'KalturaUiConf', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Clone an existing UIConf # @return [KalturaUiConf] def clone(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('uiconf', 'clone', 'KalturaUiConf', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Delete an existing UIConf # @return [] def delete(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('uiconf', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieve a UIConf by id # @return [KalturaUiConf] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('uiconf', 'get', 'KalturaUiConf', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieve a list of all available versions by object type # @return [array] def get_available_types() kparams = {} client.queue_service_action_call('uiconf', 'getAvailableTypes', 'KalturaUiConfTypeInfo', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieve a list of available UIConfs # @return [KalturaUiConfListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('uiconf', 'list', 'KalturaUiConfListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # retrieve a list of available template UIConfs # @return [KalturaUiConfListResponse] def list_templates(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('uiconf', 'listTemplates', 'KalturaUiConfListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update an existing UIConf # @return [KalturaUiConf] def update(id, ui_conf) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'uiConf', ui_conf) client.queue_service_action_call('uiconf', 'update', 'KalturaUiConf', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end class KalturaUploadService < KalturaServiceBase def initialize(client) super(client) end # @return [KalturaUploadResponse] def get_uploaded_file_token_by_file_name(file_name) kparams = {} client.add_param(kparams, 'fileName', file_name) client.queue_service_action_call('upload', 'getUploadedFileTokenByFileName', 'KalturaUploadResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [string] def upload(file_data) kparams = {} kfiles = {} client.add_param(kfiles, 'fileData', file_data) client.queue_service_action_call('upload', 'upload', 'string', kparams, kfiles) if (client.is_multirequest) return nil end return client.do_queue() end end class KalturaUploadTokenService < KalturaServiceBase def initialize(client) super(client) end # Adds new upload token to upload a file # @return [KalturaUploadToken] def add(upload_token=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'uploadToken', upload_token) client.queue_service_action_call('uploadtoken', 'add', 'KalturaUploadToken', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Deletes the upload token by upload token id # @return [] def delete(upload_token_id) kparams = {} client.add_param(kparams, 'uploadTokenId', upload_token_id) client.queue_service_action_call('uploadtoken', 'delete', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get upload token by id # @return [KalturaUploadToken] def get(upload_token_id) kparams = {} client.add_param(kparams, 'uploadTokenId', upload_token_id) client.queue_service_action_call('uploadtoken', 'get', 'KalturaUploadToken', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # List upload token by filter with pager support. # When using a user session the service will be restricted to users objects only. # @return [KalturaUploadTokenListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('uploadtoken', 'list', 'KalturaUploadTokenListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Upload a file using the upload token id, returns an error on failure (an exception will be thrown when using one of the Kaltura clients) # Chunks can be uploaded in parallel and they will be appended according to their resumeAt position. # A parallel upload session should have three stages: # 1. A single upload with resume=false and finalChunk=false # 2. Parallel upload requests each with resume=true,finalChunk=false and the expected resumetAt position. # If a chunk fails to upload it can be re-uploaded. # 3. After all of the chunks have been uploaded a final chunk (can be of zero size) should be uploaded # with resume=true, finalChunk=true and the expected resumeAt position. In case an UPLOAD_TOKEN_CANNOT_MATCH_EXPECTED_SIZE exception # has been returned (indicating not all of the chunks were appended yet) the final request can be retried. # @return [KalturaUploadToken] def upload(upload_token_id, file_data, resume=false, final_chunk=true, resume_at=-1) kparams = {} kfiles = {} client.add_param(kparams, 'uploadTokenId', upload_token_id) client.add_param(kfiles, 'fileData', file_data) client.add_param(kparams, 'resume', resume) client.add_param(kparams, 'finalChunk', final_chunk) client.add_param(kparams, 'resumeAt', resume_at) client.queue_service_action_call('uploadtoken', 'upload', 'KalturaUploadToken', kparams, kfiles) if (client.is_multirequest) return nil end return client.do_queue() end end class KalturaUserEntryService < KalturaServiceBase def initialize(client) super(client) end # Adds a user_entry to the Kaltura DB. # @return [KalturaUserEntry] def add(user_entry) kparams = {} client.add_param(kparams, 'userEntry', user_entry) client.queue_service_action_call('userentry', 'add', 'KalturaUserEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [int] def bulk_delete(filter) kparams = {} client.add_param(kparams, 'filter', filter) client.queue_service_action_call('userentry', 'bulkDelete', 'int', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaUserEntry] def delete(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('userentry', 'delete', 'KalturaUserEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaUserEntry] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('userentry', 'get', 'KalturaUserEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaUserEntryListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('userentry', 'list', 'KalturaUserEntryListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Submits the quiz so that it's status will be submitted and calculates the score for the quiz # @return [KalturaQuizUserEntry] def submit_quiz(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('userentry', 'submitQuiz', 'KalturaQuizUserEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaUserEntry] def update(id, user_entry) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'userEntry', user_entry) client.queue_service_action_call('userentry', 'update', 'KalturaUserEntry', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # UserRole service lets you create and manage user roles class KalturaUserRoleService < KalturaServiceBase def initialize(client) super(client) end # Adds a new user role object to the account. # @return [KalturaUserRole] def add(user_role) kparams = {} client.add_param(kparams, 'userRole', user_role) client.queue_service_action_call('userrole', 'add', 'KalturaUserRole', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Creates a new user role object that is a duplicate of an existing role. # @return [KalturaUserRole] def clone(user_role_id) kparams = {} client.add_param(kparams, 'userRoleId', user_role_id) client.queue_service_action_call('userrole', 'clone', 'KalturaUserRole', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Deletes an existing user role object. # @return [KalturaUserRole] def delete(user_role_id) kparams = {} client.add_param(kparams, 'userRoleId', user_role_id) client.queue_service_action_call('userrole', 'delete', 'KalturaUserRole', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieves a user role object using its ID. # @return [KalturaUserRole] def get(user_role_id) kparams = {} client.add_param(kparams, 'userRoleId', user_role_id) client.queue_service_action_call('userrole', 'get', 'KalturaUserRole', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Lists user role objects that are associated with an account. # Blocked user roles are listed unless you use a filter to exclude them. # Deleted user roles are not listed unless you use a filter to include them. # @return [KalturaUserRoleListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('userrole', 'list', 'KalturaUserRoleListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Updates an existing user role object. # @return [KalturaUserRole] def update(user_role_id, user_role) kparams = {} client.add_param(kparams, 'userRoleId', user_role_id) client.add_param(kparams, 'userRole', user_role) client.queue_service_action_call('userrole', 'update', 'KalturaUserRole', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # Manage partner users on Kaltura's side # The userId in kaltura is the unique ID in the partner's system, and the [partnerId,Id] couple are unique key in kaltura's DB class KalturaUserService < KalturaServiceBase def initialize(client) super(client) end # Adds a new user to an existing account in the Kaltura database. # Input param $id is the unique identifier in the partner's system. # @return [KalturaUser] def add(user) kparams = {} client.add_param(kparams, 'user', user) client.queue_service_action_call('user', 'add', 'KalturaUser', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # @return [KalturaBulkUpload] def add_from_bulk_upload(file_data, bulk_upload_data=KalturaNotImplemented, bulk_upload_user_data=KalturaNotImplemented) kparams = {} kfiles = {} client.add_param(kfiles, 'fileData', file_data) client.add_param(kparams, 'bulkUploadData', bulk_upload_data) client.add_param(kparams, 'bulkUploadUserData', bulk_upload_user_data) client.queue_service_action_call('user', 'addFromBulkUpload', 'KalturaBulkUpload', kparams, kfiles) if (client.is_multirequest) return nil end return client.do_queue() end # Action which checks whther user login # @return [bool] def check_login_data_exists(filter) kparams = {} client.add_param(kparams, 'filter', filter) client.queue_service_action_call('user', 'checkLoginDataExists', 'bool', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Deletes a user from a partner account. # @return [KalturaUser] def delete(user_id) kparams = {} client.add_param(kparams, 'userId', user_id) client.queue_service_action_call('user', 'delete', 'KalturaUser', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Disables a user's ability to log into a partner account using an email address and a password. # You may use either a userId or a loginId parameter for this action. # @return [KalturaUser] def disable_login(user_id=KalturaNotImplemented, login_id=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'userId', user_id) client.add_param(kparams, 'loginId', login_id) client.queue_service_action_call('user', 'disableLogin', 'KalturaUser', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Enables a user to log into a partner account using an email address and a password # @return [KalturaUser] def enable_login(user_id, login_id, password=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'userId', user_id) client.add_param(kparams, 'loginId', login_id) client.add_param(kparams, 'password', password) client.queue_service_action_call('user', 'enableLogin', 'KalturaUser', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Creates a batch job that sends an email with a link to download a CSV containing a list of users # @return [string] def export_to_csv(filter=KalturaNotImplemented, metadata_profile_id=KalturaNotImplemented, additional_fields=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'metadataProfileId', metadata_profile_id) client.add_param(kparams, 'additionalFields', additional_fields) client.queue_service_action_call('user', 'exportToCsv', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # get QR image content # @return [string] def generate_qr_code(hash_key) kparams = {} client.add_param(kparams, 'hashKey', hash_key) client.queue_service_action_call('user', 'generateQrCode', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieves a user object for a specified user ID. # @return [KalturaUser] def get(user_id=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'userId', user_id) client.queue_service_action_call('user', 'get', 'KalturaUser', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieves a user object for a user's login ID and partner ID. # A login ID is the email address used by a user to log into the system. # @return [KalturaUser] def get_by_login_id(login_id) kparams = {} client.add_param(kparams, 'loginId', login_id) client.queue_service_action_call('user', 'getByLoginId', 'KalturaUser', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Index an entry by id. # @return [string] def index(id, should_update=true) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'shouldUpdate', should_update) client.queue_service_action_call('user', 'index', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Lists user objects that are associated with an account. # Blocked users are listed unless you use a filter to exclude them. # Deleted users are not listed unless you use a filter to include them. # @return [KalturaUserListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('user', 'list', 'KalturaUserListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Logs a user into a partner account with a partner ID, a partner user ID (puser), and a user password. # @return [string] def login(partner_id, user_id, password, expiry=86400, privileges='*') kparams = {} client.add_param(kparams, 'partnerId', partner_id) client.add_param(kparams, 'userId', user_id) client.add_param(kparams, 'password', password) client.add_param(kparams, 'expiry', expiry) client.add_param(kparams, 'privileges', privileges) client.queue_service_action_call('user', 'login', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Logs a user to the destination account provided the KS' user ID is associated with the destination account and the loginData ID matches # @return [KalturaSessionResponse] def login_by_ks(requested_partner_id) kparams = {} client.add_param(kparams, 'requestedPartnerId', requested_partner_id) client.queue_service_action_call('user', 'loginByKs', 'KalturaSessionResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Logs a user into a partner account with a user login ID and a user password. # @return [string] def login_by_login_id(login_id, password, partner_id=KalturaNotImplemented, expiry=86400, privileges='*', otp=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'loginId', login_id) client.add_param(kparams, 'password', password) client.add_param(kparams, 'partnerId', partner_id) client.add_param(kparams, 'expiry', expiry) client.add_param(kparams, 'privileges', privileges) client.add_param(kparams, 'otp', otp) client.queue_service_action_call('user', 'loginByLoginId', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Notifies that a user is banned from an account. # @return [] def notify_ban(user_id) kparams = {} client.add_param(kparams, 'userId', user_id) client.queue_service_action_call('user', 'notifyBan', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Reset user's password and send the user an email to generate a new one. # @return [] def reset_password(email) kparams = {} client.add_param(kparams, 'email', email) client.queue_service_action_call('user', 'resetPassword', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Will serve a requested CSV # @return [string] def serve_csv(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('user', 'serveCsv', 'string', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Set initial user password # @return [KalturaAuthentication] def set_initial_password(hash_key, new_password) kparams = {} client.add_param(kparams, 'hashKey', hash_key) client.add_param(kparams, 'newPassword', new_password) client.queue_service_action_call('user', 'setInitialPassword', 'KalturaAuthentication', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Updates an existing user object. # You can also use this action to update the userId. # @return [KalturaUser] def update(user_id, user) kparams = {} client.add_param(kparams, 'userId', user_id) client.add_param(kparams, 'user', user) client.queue_service_action_call('user', 'update', 'KalturaUser', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Updates a user's login data: email, password, name. # @return [] def update_login_data(old_login_id, password, new_login_id='', new_password='', new_first_name=KalturaNotImplemented, new_last_name=KalturaNotImplemented, otp=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'oldLoginId', old_login_id) client.add_param(kparams, 'password', password) client.add_param(kparams, 'newLoginId', new_login_id) client.add_param(kparams, 'newPassword', new_password) client.add_param(kparams, 'newFirstName', new_first_name) client.add_param(kparams, 'newLastName', new_last_name) client.add_param(kparams, 'otp', otp) client.queue_service_action_call('user', 'updateLoginData', '', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end # widget service for full widget management class KalturaWidgetService < KalturaServiceBase def initialize(client) super(client) end # Add new widget, can be attached to entry or kshow # SourceWidget is ignored. # @return [KalturaWidget] def add(widget) kparams = {} client.add_param(kparams, 'widget', widget) client.queue_service_action_call('widget', 'add', 'KalturaWidget', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Add widget based on existing widget. # Must provide valid sourceWidgetId # @return [KalturaWidget] def clone(widget) kparams = {} client.add_param(kparams, 'widget', widget) client.queue_service_action_call('widget', 'clone', 'KalturaWidget', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Get widget by id # @return [KalturaWidget] def get(id) kparams = {} client.add_param(kparams, 'id', id) client.queue_service_action_call('widget', 'get', 'KalturaWidget', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Retrieve a list of available widget depends on the filter given # @return [KalturaWidgetListResponse] def list(filter=KalturaNotImplemented, pager=KalturaNotImplemented) kparams = {} client.add_param(kparams, 'filter', filter) client.add_param(kparams, 'pager', pager) client.queue_service_action_call('widget', 'list', 'KalturaWidgetListResponse', kparams) if (client.is_multirequest) return nil end return client.do_queue() end # Update existing widget # @return [KalturaWidget] def update(id, widget) kparams = {} client.add_param(kparams, 'id', id) client.add_param(kparams, 'widget', widget) client.queue_service_action_call('widget', 'update', 'KalturaWidget', kparams) if (client.is_multirequest) return nil end return client.do_queue() end end class KalturaClient < KalturaClientBase attr_reader :access_control_profile_service def access_control_profile_service if (@access_control_profile_service == nil) @access_control_profile_service = KalturaAccessControlProfileService.new(self) end return @access_control_profile_service end attr_reader :access_control_service def access_control_service if (@access_control_service == nil) @access_control_service = KalturaAccessControlService.new(self) end return @access_control_service end attr_reader :admin_user_service def admin_user_service if (@admin_user_service == nil) @admin_user_service = KalturaAdminUserService.new(self) end return @admin_user_service end attr_reader :analytics_service def analytics_service if (@analytics_service == nil) @analytics_service = KalturaAnalyticsService.new(self) end return @analytics_service end attr_reader :app_token_service def app_token_service if (@app_token_service == nil) @app_token_service = KalturaAppTokenService.new(self) end return @app_token_service end attr_reader :base_entry_service def base_entry_service if (@base_entry_service == nil) @base_entry_service = KalturaBaseEntryService.new(self) end return @base_entry_service end attr_reader :bulk_upload_service def bulk_upload_service if (@bulk_upload_service == nil) @bulk_upload_service = KalturaBulkUploadService.new(self) end return @bulk_upload_service end attr_reader :category_entry_service def category_entry_service if (@category_entry_service == nil) @category_entry_service = KalturaCategoryEntryService.new(self) end return @category_entry_service end attr_reader :category_service def category_service if (@category_service == nil) @category_service = KalturaCategoryService.new(self) end return @category_service end attr_reader :category_user_service def category_user_service if (@category_user_service == nil) @category_user_service = KalturaCategoryUserService.new(self) end return @category_user_service end attr_reader :conversion_profile_asset_params_service def conversion_profile_asset_params_service if (@conversion_profile_asset_params_service == nil) @conversion_profile_asset_params_service = KalturaConversionProfileAssetParamsService.new(self) end return @conversion_profile_asset_params_service end attr_reader :conversion_profile_service def conversion_profile_service if (@conversion_profile_service == nil) @conversion_profile_service = KalturaConversionProfileService.new(self) end return @conversion_profile_service end attr_reader :data_service def data_service if (@data_service == nil) @data_service = KalturaDataService.new(self) end return @data_service end attr_reader :delivery_profile_service def delivery_profile_service if (@delivery_profile_service == nil) @delivery_profile_service = KalturaDeliveryProfileService.new(self) end return @delivery_profile_service end attr_reader :email_ingestion_profile_service def email_ingestion_profile_service if (@email_ingestion_profile_service == nil) @email_ingestion_profile_service = KalturaEmailIngestionProfileService.new(self) end return @email_ingestion_profile_service end attr_reader :entry_server_node_service def entry_server_node_service if (@entry_server_node_service == nil) @entry_server_node_service = KalturaEntryServerNodeService.new(self) end return @entry_server_node_service end attr_reader :exportcsv_service def exportcsv_service if (@exportcsv_service == nil) @exportcsv_service = KalturaExportcsvService.new(self) end return @exportcsv_service end attr_reader :file_asset_service def file_asset_service if (@file_asset_service == nil) @file_asset_service = KalturaFileAssetService.new(self) end return @file_asset_service end attr_reader :flavor_asset_service def flavor_asset_service if (@flavor_asset_service == nil) @flavor_asset_service = KalturaFlavorAssetService.new(self) end return @flavor_asset_service end attr_reader :flavor_params_output_service def flavor_params_output_service if (@flavor_params_output_service == nil) @flavor_params_output_service = KalturaFlavorParamsOutputService.new(self) end return @flavor_params_output_service end attr_reader :flavor_params_service def flavor_params_service if (@flavor_params_service == nil) @flavor_params_service = KalturaFlavorParamsService.new(self) end return @flavor_params_service end attr_reader :group_user_service def group_user_service if (@group_user_service == nil) @group_user_service = KalturaGroupUserService.new(self) end return @group_user_service end attr_reader :live_channel_segment_service def live_channel_segment_service if (@live_channel_segment_service == nil) @live_channel_segment_service = KalturaLiveChannelSegmentService.new(self) end return @live_channel_segment_service end attr_reader :live_channel_service def live_channel_service if (@live_channel_service == nil) @live_channel_service = KalturaLiveChannelService.new(self) end return @live_channel_service end attr_reader :live_reports_service def live_reports_service if (@live_reports_service == nil) @live_reports_service = KalturaLiveReportsService.new(self) end return @live_reports_service end attr_reader :live_stats_service def live_stats_service if (@live_stats_service == nil) @live_stats_service = KalturaLiveStatsService.new(self) end return @live_stats_service end attr_reader :live_stream_service def live_stream_service if (@live_stream_service == nil) @live_stream_service = KalturaLiveStreamService.new(self) end return @live_stream_service end attr_reader :media_info_service def media_info_service if (@media_info_service == nil) @media_info_service = KalturaMediaInfoService.new(self) end return @media_info_service end attr_reader :media_service def media_service if (@media_service == nil) @media_service = KalturaMediaService.new(self) end return @media_service end attr_reader :mixing_service def mixing_service if (@mixing_service == nil) @mixing_service = KalturaMixingService.new(self) end return @mixing_service end attr_reader :notification_service def notification_service if (@notification_service == nil) @notification_service = KalturaNotificationService.new(self) end return @notification_service end attr_reader :partner_service def partner_service if (@partner_service == nil) @partner_service = KalturaPartnerService.new(self) end return @partner_service end attr_reader :permission_item_service def permission_item_service if (@permission_item_service == nil) @permission_item_service = KalturaPermissionItemService.new(self) end return @permission_item_service end attr_reader :permission_service def permission_service if (@permission_service == nil) @permission_service = KalturaPermissionService.new(self) end return @permission_service end attr_reader :playlist_service def playlist_service if (@playlist_service == nil) @playlist_service = KalturaPlaylistService.new(self) end return @playlist_service end attr_reader :report_service def report_service if (@report_service == nil) @report_service = KalturaReportService.new(self) end return @report_service end attr_reader :response_profile_service def response_profile_service if (@response_profile_service == nil) @response_profile_service = KalturaResponseProfileService.new(self) end return @response_profile_service end attr_reader :schema_service def schema_service if (@schema_service == nil) @schema_service = KalturaSchemaService.new(self) end return @schema_service end attr_reader :search_service def search_service if (@search_service == nil) @search_service = KalturaSearchService.new(self) end return @search_service end attr_reader :server_node_service def server_node_service if (@server_node_service == nil) @server_node_service = KalturaServerNodeService.new(self) end return @server_node_service end attr_reader :session_service def session_service if (@session_service == nil) @session_service = KalturaSessionService.new(self) end return @session_service end attr_reader :stats_service def stats_service if (@stats_service == nil) @stats_service = KalturaStatsService.new(self) end return @stats_service end attr_reader :storage_profile_service def storage_profile_service if (@storage_profile_service == nil) @storage_profile_service = KalturaStorageProfileService.new(self) end return @storage_profile_service end attr_reader :syndication_feed_service def syndication_feed_service if (@syndication_feed_service == nil) @syndication_feed_service = KalturaSyndicationFeedService.new(self) end return @syndication_feed_service end attr_reader :system_service def system_service if (@system_service == nil) @system_service = KalturaSystemService.new(self) end return @system_service end attr_reader :thumb_asset_service def thumb_asset_service if (@thumb_asset_service == nil) @thumb_asset_service = KalturaThumbAssetService.new(self) end return @thumb_asset_service end attr_reader :thumb_params_output_service def thumb_params_output_service if (@thumb_params_output_service == nil) @thumb_params_output_service = KalturaThumbParamsOutputService.new(self) end return @thumb_params_output_service end attr_reader :thumb_params_service def thumb_params_service if (@thumb_params_service == nil) @thumb_params_service = KalturaThumbParamsService.new(self) end return @thumb_params_service end attr_reader :ui_conf_service def ui_conf_service if (@ui_conf_service == nil) @ui_conf_service = KalturaUiConfService.new(self) end return @ui_conf_service end attr_reader :upload_service def upload_service if (@upload_service == nil) @upload_service = KalturaUploadService.new(self) end return @upload_service end attr_reader :upload_token_service def upload_token_service if (@upload_token_service == nil) @upload_token_service = KalturaUploadTokenService.new(self) end return @upload_token_service end attr_reader :user_entry_service def user_entry_service if (@user_entry_service == nil) @user_entry_service = KalturaUserEntryService.new(self) end return @user_entry_service end attr_reader :user_role_service def user_role_service if (@user_role_service == nil) @user_role_service = KalturaUserRoleService.new(self) end return @user_role_service end attr_reader :user_service def user_service if (@user_service == nil) @user_service = KalturaUserService.new(self) end return @user_service end attr_reader :widget_service def widget_service if (@widget_service == nil) @widget_service = KalturaWidgetService.new(self) end return @widget_service end def initialize(client) super(client) self.client_tag = 'ruby:20-01-06' self.api_version = '15.14.0' end def client_tag=(value) @client_configuration['clientTag'] = value end def set_client_tag(value) self.client_tag = value end def client_tag() if(@client_configuration.has_key?('clientTag')) return @client_configuration['clientTag'] end return KalturaNotImplemented end def get_client_tag() return self.client_tag end def api_version=(value) @client_configuration['apiVersion'] = value end def set_api_version(value) self.api_version = value end def api_version() if(@client_configuration.has_key?('apiVersion')) return @client_configuration['apiVersion'] end return KalturaNotImplemented end def get_api_version() return self.api_version end def partner_id=(value) @request_configuration['partnerId'] = value end def set_partner_id(value) self.partner_id = value end def partner_id() if(@request_configuration.has_key?('partnerId')) return @request_configuration['partnerId'] end return KalturaNotImplemented end def get_partner_id() return self.partner_id end def ks=(value) @request_configuration['ks'] = value end def set_ks(value) self.ks = value end def ks() if(@request_configuration.has_key?('ks')) return @request_configuration['ks'] end return KalturaNotImplemented end def get_ks() return self.ks end def session_id=(value) @request_configuration['ks'] = value end def set_session_id(value) self.session_id = value end def session_id() if(@request_configuration.has_key?('ks')) return @request_configuration['ks'] end return KalturaNotImplemented end def get_session_id() return self.session_id end def response_profile=(value) @request_configuration['responseProfile'] = value end def set_response_profile(value) self.response_profile = value end def response_profile() if(@request_configuration.has_key?('responseProfile')) return @request_configuration['responseProfile'] end return KalturaNotImplemented end def get_response_profile() return self.response_profile end def reset_request() super @request_configuration.delete('responseProfile') end end end