Skip to content

Ziggeo/ZiggeoJavaSdk

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

57 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Ziggeo's Java Server SDK

latest version: 0.1.30

Index

  1. Why Ziggeo's Java Server Side SDK?
  2. Prerequisites
    1. Download
    2. How to use
    3. Installation
    4. Building
    5. Demo
  3. Client-Side Integration
  4. Server-Side Integration
    1. Init
    2. Available Methods
    3. Methods for Videos
      1. Videos Index
      2. Videos Count
      3. Videos Get
      4. Videos GetBulk
      5. Videos StatsBulk
      6. Videos DownloadVideo
      7. Videos DownloadImage
      8. Videos GetStats
      9. Videos PushToService
      10. Videos ApplyEffect
      11. Videos ApplyMeta
      12. Videos Update
      13. Videos UpdateBulk
      14. Videos Delete
      15. Videos Create
      16. Videos Analytics
    4. Methods for Streams
      1. Streams Index
      2. Streams Get
      3. Streams DownloadVideo
      4. Streams DownloadImage
      5. Streams PushToService
      6. Streams Delete
      7. Streams Create
      8. Streams AttachImage
      9. Streams AttachVideo
      10. Streams AttachSubtitle
    5. Methods for Audios
      1. Audios Index
      2. Audios Count
      3. Audios Get
      4. Audios GetBulk
      5. Audios DownloadAudio
      6. Audios Update
      7. Audios UpdateBulk
      8. Audios Delete
      9. Audios Create
    6. Methods for Audio Streams
      1. Audio Streams Index
      2. Audio Streams Get
      3. Audio Streams DownloadAudio
      4. Audio Streams Delete
      5. Audio Streams Create
    7. Methods for Authtokens
      1. Authtokens Get
      2. Authtokens Update
      3. Authtokens Delete
      4. Authtokens Create
    8. Methods for Application
      1. Application Get
      2. Application Update
      3. Application GetStats
    9. Methods for Effect Profiles
      1. Effect Profiles Create
      2. Effect Profiles Index
      3. Effect Profiles Get
      4. Effect Profiles Delete
      5. Effect Profiles Update
    10. Methods for Effect Profile Process
      1. Effect Profile Process Index
      2. Effect Profile Process Get
      3. Effect Profile Process Delete
      4. Effect Profile Process CreateFilterProcess
      5. Effect Profile Process CreateWatermarkProcess
      6. Effect Profile Process EditWatermarkProcess
    11. Methods for Meta Profiles
      1. Meta Profiles Create
      2. Meta Profiles Index
      3. Meta Profiles Get
      4. Meta Profiles Delete
    12. Methods for Meta Profile Process
      1. Meta Profile Process Index
      2. Meta Profile Process Get
      3. Meta Profile Process Delete
      4. Meta Profile Process CreateVideoAnalysisProcess
      5. Meta Profile Process CreateAudioTranscriptionProcess
      6. Meta Profile Process CreateNsfwProcess
      7. Meta Profile Process CreateProfanityProcess
    13. Methods for Webhooks
      1. Webhooks Create
      2. Webhooks Confirm
      3. Webhooks Delete
    14. Methods for Analytics
      1. Analytics Get
  5. License

Why Ziggeo's Java 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?

  1. Do you have a system that requires calls to be made which should not be seen on client side?
  2. Want to have an easier time handling the media as it comes to your server?
  3. Want something that is simple and easy to use?
  4. 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 java git clone https://github.com/Ziggeo/ZiggeoJavaSdk

How to use

To start using the Java 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.

Installation

Make sure to install Java Cryptography Extension (JCE) Unlimited Strength.

Building

mvn clean install

## Demo<a name="demo"></a>

mvn exec:java -Dexec.mainClass=com.ziggeo.demos.VideoListLimit -Dexec.args='TOKEN PRIVATE_KEY SKIP LIMIT'

Client-Side Integration

For the client-side integration, you need to add these assets to your html file:

<link rel="stylesheet" href="//assets-cdn.ziggeo.com/v2-stable/ziggeo.css" />
<script src="//assets-cdn.ziggeo.com/v2-stable/ziggeo.js"></script>

Then, you need to specify your api token:

<script>
    var ziggeoApplication = new ZiggeoApi.V2.Application({
        token: "APPLICATION_TOKEN",
        webrtc_streaming_if_necessary: true,
        webrtc_on_mobile: true
    });
</script>

You can specify other global options, see here.

To fire up a recorder on your page, add:

<ziggeorecorder></ziggeorecorder>

To embed a player for an existing video, add:

<ziggeoplayer ziggeo-video='video-token'></ziggeoplayer>

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:

Ziggeo ziggeo = new Ziggeo("*token*", "*privateKey*", "*encryptionKey*"); 

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:

  1. Videos
  2. Streams
  3. Audios
  4. Audio Streams
  5. Authtokens
  6. Application
  7. Effect Profiles
  8. Effect Profile Process
  9. Meta Profiles
  10. Meta Profile Process
  11. Webhooks
  12. 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.

ziggeo.videos().index(JSONObject arguments)

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.

ziggeo.videos().count(JSONObject arguments)

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.

ziggeo.videos().get(String tokenOrKey)

Get Bulk

Get multiple videos by tokens or keys.

ziggeo.videos().getBulk(JSONObject arguments)

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.

ziggeo.videos().statsBulk(JSONObject arguments)

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

ziggeo.videos().downloadVideo(String tokenOrKey)

Download Image

Download the image data file

ziggeo.videos().downloadImage(String tokenOrKey)

Get Stats

Get the video's stats

ziggeo.videos().getStats(String tokenOrKey)

Push To Service

Push a video to a provided push service.

ziggeo.videos().pushToService(String tokenOrKey, JSONObject arguments)

Arguments

  • pushservicetoken: Push Services's token (from the Push Services configured for the app)

Apply Effect

Apply an effect profile to a video.

ziggeo.videos().applyEffect(String tokenOrKey, JSONObject arguments)

Arguments

  • effectprofiletoken: Effect Profile token (from the Effect Profiles configured for the app)

Apply Meta

Apply a meta profile to a video.

ziggeo.videos().applyMeta(String tokenOrKey, JSONObject arguments)

Arguments

  • metaprofiletoken: Meta Profile token (from the Meta Profiles configured for the app)

Update

Update single video by token or key.

ziggeo.videos().update(String tokenOrKey, JSONObject arguments)

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.

ziggeo.videos().updateBulk(JSONObject arguments)

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.

ziggeo.videos().delete(String tokenOrKey)

Create

Create a new video.

ziggeo.videos().create(JSONObject arguments, String file)

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

ziggeo.videos().analytics(String tokenOrKey, JSONObject arguments)

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

ziggeo.streams().index(String videoTokenOrKey, JSONObject arguments)

Arguments

  • states: Filter streams by state

Get

Get a single stream

ziggeo.streams().get(String videoTokenOrKey, String tokenOrKey)

Download Video

Download the video data associated with the stream

ziggeo.streams().downloadVideo(String videoTokenOrKey, String tokenOrKey)

Download Image

Download the image data associated with the stream

ziggeo.streams().downloadImage(String videoTokenOrKey, String tokenOrKey)

Push To Service

Push a stream to a provided push service.

ziggeo.streams().pushToService(String videoTokenOrKey, String tokenOrKey, JSONObject arguments)

Arguments

  • pushservicetoken: Push Services's token (from the Push Services configured for the app)

Delete

Delete the stream

ziggeo.streams().delete(String videoTokenOrKey, String tokenOrKey)

Create

Create a new stream

ziggeo.streams().create(String videoTokenOrKey, JSONObject arguments, String file)

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

ziggeo.streams().attachImage(String videoTokenOrKey, String tokenOrKey, JSONObject arguments, String file)

Arguments

  • file: Image file to be attached

Attach Video

Attaches a video to a new stream

ziggeo.streams().attachVideo(String videoTokenOrKey, String tokenOrKey, JSONObject arguments, String file)

Arguments

  • file: Video file to be attached

Attach Subtitle

Attaches a subtitle to the stream.

ziggeo.streams().attachSubtitle(String videoTokenOrKey, String tokenOrKey, JSONObject arguments)

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.

ziggeo.audios().index(JSONObject arguments)

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.

ziggeo.audios().count(JSONObject arguments)

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.

ziggeo.audios().get(String tokenOrKey)

Get Bulk

Get multiple audios by tokens or keys.

ziggeo.audios().getBulk(JSONObject arguments)

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

ziggeo.audios().downloadAudio(String tokenOrKey)

Update

Update single audio by token or key.

ziggeo.audios().update(String tokenOrKey, JSONObject arguments)

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.

ziggeo.audios().updateBulk(JSONObject arguments)

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.

ziggeo.audios().delete(String tokenOrKey)

Create

Create a new audio.

ziggeo.audios().create(JSONObject arguments, String file)

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

ziggeo.audioStreams().index(String audioTokenOrKey, JSONObject arguments)

Arguments

  • states: Filter streams by state

Get

Get a single stream

ziggeo.audioStreams().get(String audioTokenOrKey, String tokenOrKey)

Download Audio

Download the audio data associated with the stream

ziggeo.audioStreams().downloadAudio(String audioTokenOrKey, String tokenOrKey)

Delete

Delete the stream

ziggeo.audioStreams().delete(String audioTokenOrKey, String tokenOrKey)

Create

Create a new stream

ziggeo.audioStreams().create(String audioTokenOrKey, JSONObject arguments, String file)

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.

ziggeo.authtokens().get(String token)

Update

Update single auth token by token.

ziggeo.authtokens().update(String tokenOrKey, JSONObject arguments)

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.

ziggeo.authtokens().delete(String tokenOrKey)

Create

Create a new auth token.

ziggeo.authtokens().create(JSONObject arguments)

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.

ziggeo.application().get()

Update

Update application.

ziggeo.application().update(JSONObject arguments)

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

ziggeo.application().getStats(JSONObject arguments)

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.

ziggeo.effectProfiles().create(JSONObject arguments)

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.

ziggeo.effectProfiles().index(JSONObject arguments)

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

ziggeo.effectProfiles().get(String tokenOrKey)

Delete

Delete the effect profile

ziggeo.effectProfiles().delete(String tokenOrKey)

Update

Updates an effect profile.

ziggeo.effectProfiles().update(String tokenOrKey, JSONObject arguments)

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

ziggeo.effectProfileProcess().index(String effectTokenOrKey, JSONObject arguments)

Arguments

  • states: Filter streams by state

Get

Get a single process

ziggeo.effectProfileProcess().get(String effectTokenOrKey, String tokenOrKey)

Delete

Delete the process

ziggeo.effectProfileProcess().delete(String effectTokenOrKey, String tokenOrKey)

Create Filter Process

Create a new filter effect process

ziggeo.effectProfileProcess().createFilterProcess(String effectTokenOrKey, JSONObject arguments)

Arguments

  • effect: Effect to be applied in the process

Create Watermark Process

Attaches an image to a new stream

ziggeo.effectProfileProcess().createWatermarkProcess(String effectTokenOrKey, JSONObject arguments, String file)

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.

ziggeo.effectProfileProcess().editWatermarkProcess(String effectTokenOrKey, String tokenOrKey, JSONObject arguments, String file)

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.

ziggeo.metaProfiles().create(JSONObject arguments)

Arguments

  • key: Meta Profile profile key.
  • title: Meta Profile profile title.

Index

Get list of meta profiles.

ziggeo.metaProfiles().index(JSONObject arguments)

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

ziggeo.metaProfiles().get(String tokenOrKey)

Delete

Delete the meta profile

ziggeo.metaProfiles().delete(String tokenOrKey)

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

ziggeo.metaProfileProcess().index(String metaTokenOrKey)

Get

Get a single process

ziggeo.metaProfileProcess().get(String metaTokenOrKey, String tokenOrKey)

Delete

Delete the process

ziggeo.metaProfileProcess().delete(String metaTokenOrKey, String tokenOrKey)

Create Video Analysis Process

Create a new video analysis meta process

ziggeo.metaProfileProcess().createVideoAnalysisProcess(String metaTokenOrKey)

Create Audio Transcription Process

Create a new audio transcription meta process

ziggeo.metaProfileProcess().createAudioTranscriptionProcess(String metaTokenOrKey)

Create Nsfw Process

Create a new nsfw filter meta process

ziggeo.metaProfileProcess().createNsfwProcess(String metaTokenOrKey, JSONObject arguments)

Arguments

  • nsfw_action: One of the following three: approve, reject, nothing.

Create Profanity Process

Create a new profanity filter meta process

ziggeo.metaProfileProcess().createProfanityProcess(String metaTokenOrKey, JSONObject arguments)

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.

ziggeo.webhooks().create(JSONObject arguments)

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.

ziggeo.webhooks().confirm(JSONObject arguments)

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.

ziggeo.webhooks().delete(JSONObject arguments)

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

ziggeo.analytics().get(JSONObject arguments)

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

License

Copyright (c) 2013-2022 Ziggeo

Apache 2.0 License