Download the PHP package ziggeo/ziggeophpsdk without Composer
On this page you can find all versions of the php package ziggeo/ziggeophpsdk. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download ziggeo/ziggeophpsdk
More information about ziggeo/ziggeophpsdk
Files in ziggeo/ziggeophpsdk
Package ziggeophpsdk
Short Description Ziggeo API (https://ziggeo.com) allows you to integrate video recording and playback with only two lines of code in your site, service or app.
License Apache-2.0
Informations about the package ziggeophpsdk
Ziggeo's PHP Server SDK
latest version: 0.1.30
Index
- Why Ziggeo's PHP Server Side SDK?
- Prerequisites
- Download
- How to use
- Dependencies
- Client-Side Integration
- Server-Side Integration
- Init
- Available Methods
- Methods for Videos
- Videos Index
- Videos Count
- Videos Get
- Videos Get Bulk
- Videos Stats Bulk
- Videos Download Video
- Videos Download Image
- Videos Get Stats
- Videos Push To Service
- Videos Apply Effect
- Videos Apply Meta
- Videos Update
- Videos Update Bulk
- Videos Delete
- Videos Create
- Videos Analytics
- Methods for Streams
- Streams Index
- Streams Get
- Streams Download Video
- Streams Download Image
- Streams Push To Service
- Streams Delete
- Streams Create
- Streams Attach Image
- Streams Attach Video
- Streams Attach Subtitle
- Methods for Audios
- Audios Index
- Audios Count
- Audios Get
- Audios Get Bulk
- Audios Download Audio
- Audios Update
- Audios Update Bulk
- Audios Delete
- Audios Create
- Methods for Audio Streams
- Audio Streams Index
- Audio Streams Get
- Audio Streams Download Audio
- Audio Streams Delete
- Audio Streams Create
- Methods for Authtokens
- Authtokens Get
- Authtokens Update
- Authtokens Delete
- Authtokens Create
- Methods for Application
- Application Get
- Application Update
- Application Get Stats
- Methods for Effect Profiles
- Effect Profiles Create
- Effect Profiles Index
- Effect Profiles Get
- Effect Profiles Delete
- Effect Profiles Update
- Methods for Effect Profile Process
- Effect Profile Process Index
- Effect Profile Process Get
- Effect Profile Process Delete
- Effect Profile Process Create Filter Process
- Effect Profile Process Create Watermark Process
- Effect Profile Process Edit Watermark Process
- Methods for Meta Profiles
- Meta Profiles Create
- Meta Profiles Index
- Meta Profiles Get
- Meta Profiles Delete
- Methods for Meta Profile Process
- Meta Profile Process Index
- Meta Profile Process Get
- Meta Profile Process Delete
- Meta Profile Process Create Video Analysis Process
- Meta Profile Process Create Audio Transcription Process
- Meta Profile Process Create Nsfw Process
- Meta Profile Process Create Profanity Process
- Methods for Webhooks
- Webhooks Create
- Webhooks Confirm
- Webhooks Delete
- Methods for Analytics
- Analytics Get
- Useful
- Using with Docker
- Testing Webhooks
- License
Why Ziggeo's PHP Server Side SDK?
Ziggeo is a powerfull, whitelabel video SAAS with a goal to help people with their video revolution. And what better way to do it than with an award winning multimedia API.
This server side SDK is designed to help you ease the communication with Ziggeo API. In that it allows you to privately communicate between your server and our server through requests of what you want to happen.
It offers you pre-built functionality to call and manipulate and there are demos in /demos/ directory for you to check out and use as starting point.
Who it is for?
- Do you have a system that requires calls to be made which should not be seen on client side?
- Want to have an easier time handling the media as it comes to your server?
- Want something that is simple and easy to use?
- You need some powerful features high end video services provide?
If any of the above is "Yes" then you are in the right place as this SDK is for you!
Prerequisites
Download
You will want to either download the SDK zip file or to pull it in as git repository into your own project.
To clone it you would go into your project folder and then
How to use
To start using the PHP SDK you would need to initialize the Ziggeo class with application token, private token and possibly encryption token. The token and keys can be found within the Ziggeo application once you log into your account, under Overview page.
Dependencies
If you are using Auth tokens you would need to install PHPSeclib library, at least for the client auth tokens to be created.
If you are using Composer, you would do the following steps:
- Run
composer require phpseclib/phpseclib
within the folder - Edit the Ziggeo.php file and add
require_once 'vendor/autoload.php';
at the very top. -PHPSeclibClient-Side Integration
For the client-side integration, you need to add these assets to your html file:
Then, you need to specify your api token:
You can specify other global options, see here.
To fire up a recorder on your page, add:
To embed a player for an existing video, add:
For the full documentation, please visit ziggeo.com.
Server-Side Integration
Initialize Ziggeo class in your code
You can integrate the Server SDK as follows:
Config is optional and if not specified (recommended), the Config file will be used instead.
Available Methods
Currently available methods are branched off within different categories:
- Videos
- Streams
- Audios
- Audio Streams
- Authtokens
- Application
- Effect Profiles
- Effect Profile Process
- Meta Profiles
- Meta Profile Process
- Webhooks
- Analytics
Each of this sections has their own actions and they are explained bellow
Videos
The videos resource allows you to access all single videos. Each video may contain more than one stream.
Index
Query an array of videos (will return at most 50 videos by default). Newest videos come first.
Arguments
- limit: Limit the number of returned videos. Can be set up to 100.
- skip: Skip the first [n] entries.
- reverse: Reverse the order in which videos are returned.
- states: Filter videos by state
- tags: Filter the search result to certain tags, encoded as a comma-separated string
Count
Get the video count for the application.
Arguments
- states: Filter videos by state
- tags: Filter the search result to certain tags, encoded as a comma-separated string
Get
Get a single video by token or key.
Get Bulk
Get multiple videos by tokens or keys.
Arguments
- tokens_or_keys: Comma-separated list with the desired videos tokens or keys (Limit: 100 tokens or keys).
Stats Bulk
Get stats for multiple videos by tokens or keys.
Arguments
- tokens_or_keys: Comma-separated list with the desired videos tokens or keys (Limit: 100 tokens or keys).
- summarize: Boolean. Set it to TRUE to get the stats summarized. Set it to FALSE to get the stats for each video in a separate array. Default: TRUE.
Download Video
Download the video data file
Download Image
Download the image data file
Get Stats
Get the video's stats
Push To Service
Push a video to a provided push service.
Arguments
- pushservicetoken: Push Services's token (from the Push Services configured for the app)
Apply Effect
Apply an effect profile to a video.
Arguments
- effectprofiletoken: Effect Profile token (from the Effect Profiles configured for the app)
Apply Meta
Apply a meta profile to a video.
Arguments
- metaprofiletoken: Meta Profile token (from the Meta Profiles configured for the app)
Update
Update single video by token or key.
Arguments
- min_duration: Minimal duration of video
- max_duration: Maximal duration of video
- tags: Video Tags
- key: Unique (optional) name of video
- volatile: Automatically removed this video if it remains empty
- expiration_days: After how many days will this video be deleted
- expire_on: On which date will this video be deleted. String in ISO 8601 format: YYYY-MM-DD
Update Bulk
Update multiple videos by token or key.
Arguments
- tokens_or_keys: Comma-separated list with the desired videos tokens or keys (Limit: 100 tokens or keys).
- min_duration: Minimal duration of video
- max_duration: Maximal duration of video
- tags: Video Tags
- volatile: Automatically removed this video if it remains empty
- expiration_days: After how many days will this video be deleted
- expire_on: On which date will this video be deleted. String in ISO 8601 format: YYYY-MM-DD
Delete
Delete a single video by token or key.
Create
Create a new video.
Arguments
- file: Video file to be uploaded
- min_duration: Minimal duration of video
- max_duration: Maximal duration of video
- tags: Video Tags
- key: Unique (optional) name of video
- volatile: Automatically removed this video if it remains empty
- effect_profile: Set the effect profile that you want to have applied to your video.
- meta_profile: Set the meta profile that you want to have applied to your video once created.
- video_profile: Set the video profile that you want to have applied to your video as you create it.
Analytics
Get analytics for a specific videos with the given params
Arguments
- from: A UNIX timestamp in microseconds used as the start date of the query
- to: A UNIX timestamp in microseconds used as the end date of the query
- date: A UNIX timestamp in microseconds to retrieve data from a single date. If set, it overwrites the from and to params.
- query: The query you want to run. It can be one of the following: device_views_by_os, device_views_by_date, total_plays_by_country, full_plays_by_country, total_plays_by_hour, full_plays_by_hour, total_plays_by_browser, full_plays_by_browser
Streams
The streams resource allows you to directly access all streams associated with a single video.
Index
Return all streams associated with a video
Arguments
- states: Filter streams by state
Get
Get a single stream
Download Video
Download the video data associated with the stream
Download Image
Download the image data associated with the stream
Push To Service
Push a stream to a provided push service.
Arguments
- pushservicetoken: Push Services's token (from the Push Services configured for the app)
Delete
Delete the stream
Create
Create a new stream
Arguments
- file: Video file to be uploaded
Attach Image
Attaches an image to a new stream. Must be attached before video, since video upload triggers the transcoding job and binds the stream
Arguments
- file: Image file to be attached
Attach Video
Attaches a video to a new stream
Arguments
- file: Video file to be attached
Attach Subtitle
Attaches a subtitle to the stream.
Arguments
- lang: Subtitle language
- label: Subtitle reference
- data: Actual subtitle
Audios
The audios resource allows you to access all single audios. Each video may contain more than one stream.
Index
Query an array of audios (will return at most 50 audios by default). Newest audios come first.
Arguments
- limit: Limit the number of returned audios. Can be set up to 100.
- skip: Skip the first [n] entries.
- reverse: Reverse the order in which audios are returned.
- states: Filter audios by state
- tags: Filter the search result to certain tags, encoded as a comma-separated string
Count
Get the audio count for the application.
Arguments
- states: Filter audios by state
- tags: Filter the search result to certain tags, encoded as a comma-separated string
Get
Get a single audio by token or key.
Get Bulk
Get multiple audios by tokens or keys.
Arguments
- tokens_or_keys: Comma-separated list with the desired audios tokens or keys (Limit: 100 tokens or keys).
Download Audio
Download the audio data file
Update
Update single audio by token or key.
Arguments
- min_duration: Minimal duration of audio
- max_duration: Maximal duration of audio
- tags: Audio Tags
- key: Unique (optional) name of audio
- volatile: Automatically removed this audio if it remains empty
- expiration_days: After how many days will this audio be deleted
- expire_on: On which date will this audio be deleted. String in ISO 8601 format: YYYY-MM-DD
Update Bulk
Update multiple audios by token or key.
Arguments
- tokens_or_keys: Comma-separated list with the desired audios tokens or keys (Limit: 100 tokens or keys).
- min_duration: Minimal duration of audio
- max_duration: Maximal duration of audio
- tags: Audio Tags
- volatile: Automatically removed this audio if it remains empty
- expiration_days: After how many days will this audio be deleted
- expire_on: On which date will this audio be deleted. String in ISO 8601 format: YYYY-MM-DD
Delete
Delete a single audio by token or key.
Create
Create a new audio.
Arguments
- file: Audio file to be uploaded
- min_duration: Minimal duration of audio
- max_duration: Maximal duration of audio
- tags: Audio Tags
- key: Unique (optional) name of audio
- volatile: Automatically removed this video if it remains empty
Audio Streams
The streams resource allows you to directly access all streams associated with a single audio.
Index
Return all streams associated with a audio
Arguments
- states: Filter streams by state
Get
Get a single stream
Download Audio
Download the audio data associated with the stream
Delete
Delete the stream
Create
Create a new stream
Arguments
- file: Audio file to be uploaded
Authtokens
The auth token resource allows you to manage authorization settings for video objects.
Get
Get a single auth token by token.
Update
Update single auth token by token.
Arguments
- volatile: Will this object automatically be deleted if it remains empty?
- hidden: If hidden, the token cannot be used directly.
- expiration_date: Expiration date for the auth token (Unix epoch time format)
- usage_expiration_time: Expiration time per session (seconds)
- session_limit: Maximal number of sessions
- grants: Permissions this tokens grants
Delete
Delete a single auth token by token.
Create
Create a new auth token.
Arguments
- volatile: Will this object automatically be deleted if it remains empty?
- hidden: If hidden, the token cannot be used directly.
- expiration_date: Expiration date for the auth token (Unix epoch time format)
- usage_expiration_time: Expiration time per session (seconds)
- session_limit: Maximal number of sessions
- grants: Permissions this tokens grants
Application
The application token resource allows you to manage your application.
Get
Read application.
Update
Update application.
Arguments
- volatile: Will this object automatically be deleted if it remains empty?
- name: Name of the application
- auth_token_required_for_create: Require auth token for creating videos
- auth_token_required_for_update: Require auth token for updating videos
- auth_token_required_for_read: Require auth token for reading videos
- auth_token_required_for_destroy: Require auth token for deleting videos
- client_can_index_videos: Client is allowed to perform the index operation
- client_cannot_access_unaccepted_videos: Client cannot view unaccepted videos
- enable_video_subpages: Enable hosted video pages
Get Stats
Read application stats
Arguments
- period: Optional. Can be 'year' or 'month'.
Effect Profiles
The effect profiles resource allows you to access and create effect profiles for your app. Each effect profile may contain one process or more.
Create
Create a new effect profile.
Arguments
- key: Effect profile key.
- title: Effect profile title.
- default_effect: Boolean. If TRUE, sets an effect profile as default. If FALSE, removes the default status for the given effect
Index
Get list of effect profiles.
Arguments
- limit: Limit the number of returned effect profiles. Can be set up to 100.
- skip: Skip the first [n] entries.
- reverse: Reverse the order in which effect profiles are returned.
Get
Get a single effect profile
Delete
Delete the effect profile
Update
Updates an effect profile.
Arguments
- default_effect: Boolean. If TRUE, sets an effect profile as default. If FALSE, removes the default status for the given effect
Effect Profile Process
The process resource allows you to directly access all process associated with a single effect profile.
Index
Return all processes associated with a effect profile
Arguments
- states: Filter streams by state
Get
Get a single process
Delete
Delete the process
Create Filter Process
Create a new filter effect process
Arguments
- effect: Effect to be applied in the process
Create Watermark Process
Attaches an image to a new stream
Arguments
- file: Image file to be attached
- vertical_position: Specify the vertical position of your watermark (a value between 0.0 and 1.0)
- horizontal_position: Specify the horizontal position of your watermark (a value between 0.0 and 1.0)
- video_scale: Specify the image scale of your watermark (a value between 0.0 and 1.0)
Edit Watermark Process
Edits an existing watermark process.
Arguments
- file: Image file to be attached
- vertical_position: Specify the vertical position of your watermark (a value between 0.0 and 1.0)
- horizontal_position: Specify the horizontal position of your watermark (a value between 0.0 and 1.0)
- video_scale: Specify the image scale of your watermark (a value between 0.0 and 1.0)
Meta Profiles
The meta profiles resource allows you to access and create meta profiles for your app. Each meta profile may contain one process or more.
Create
Create a new meta profile.
Arguments
- key: Meta Profile profile key.
- title: Meta Profile profile title.
Index
Get list of meta profiles.
Arguments
- limit: Limit the number of returned meta profiles. Can be set up to 100.
- skip: Skip the first [n] entries.
- reverse: Reverse the order in which meta profiles are returned.
Get
Get a single meta profile
Delete
Delete the meta profile
Meta Profile Process
The process resource allows you to directly access all process associated with a single meta profile.
Index
Return all processes associated with a meta profile
Get
Get a single process
Delete
Delete the process
Create Video Analysis Process
Create a new video analysis meta process
Create Audio Transcription Process
Create a new audio transcription meta process
Create Nsfw Process
Create a new nsfw filter meta process
Arguments
- nsfw_action: One of the following three: approve, reject, nothing.
Create Profanity Process
Create a new profanity filter meta process
Arguments
- profanity_action: One of the following three: approve, reject, nothing.
Webhooks
The webhooks resource allows you to create or delete webhooks related to a given application.
Create
Create a new webhook for the given url to catch the given events.
Arguments
- target_url: The url that will catch the events
- encoding: Data encoding to be used by the webhook to send the events.
- events: Comma-separated list of the events the webhook will catch. They must be valid webhook type events.
Confirm
Confirm a webhook using its ID and the corresponding validation code.
Arguments
- webhook_id: Webhook ID that's returned in the creation call.
- validation_code: Validation code that is sent to the webhook when created.
Delete
Delete a webhook using its URL.
Arguments
- target_url: The url that will catch the events
Analytics
The analytics resource allows you to access the analytics for the given application
Get
Get analytics for the given params
Arguments
- from: A UNIX timestamp in microseconds used as the start date of the query
- to: A UNIX timestamp in microseconds used as the end date of the query
- date: A UNIX timestamp in microseconds to retrieve data from a single date. If set, it overwrites the from and to params.
- query: The query you want to run. It can be one of the following: device_views_by_os, device_views_by_date, total_plays_by_country, full_plays_by_country, total_plays_by_hour, full_plays_by_hour, total_plays_by_browser, full_plays_by_browser
Docker
If you prefer to run this SDK and its demos using Docker, build the image as follows:
You can then run demos as follows:
Webhooks
While you technically do not need this SDK to receive webhooks, we have included a demo for your convenience.
Run as follows:
If you want to use docker, run as follows:
Your local machine needs to be accessible from the internet via port 12345. In most cases, you will be behind a router / NAT, so you will either need to activate some sort of port forwarding or install a local port tunnel like ngrok.
Once such a tunnel is being installed, you can usually tunnel a particular port like 12345 as follows:
The output will then provide you with a particular publicly accessible domain name that you can add to your Ziggeo webhook list:
License
Copyright (c) 2013-2022 Ziggeo
Apache 2.0 License