JSPM

media-platform-js-sdk

0.6.5-alpha6
  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 1186
  • Score
    100M100P100Q111876F
  • License Apache-2.0

A SDK to access Wix Media Platform image manipulation API and upload capabilities

Package Exports

  • media-platform-js-sdk

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (media-platform-js-sdk) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

Wix Media Platform

NPM version Downloads

Wix Media Platform is a collection of services for storing, serving, uploading, and managing image, audio, and video files.

Image

Wix Media Platform provides powerful image-processing services that support resizing, cropping, rotating, sharpening, and face-detection, as well as offering a number of filters and adjustments. Images can be easily served with on-the-fly manipulations using the Wix Media Platform SDKs or Image API.

See it in action.

Audio

Wix Media Platform provides storage for professional, high-quality audio files that can then be used in commercial music-selling applications.

Video

Video files uploaded to Wix Media Platform are automatically transcoded into additional formats of various qualities, enabling video playback on any browser or Internet-connected device.

For video playback see Vidi - Adaptive video playback library.

Documents

In addition, Wix Media Platform supports uploading and distribution of documents such as Excel and Word.

JavaScript SDK

This package is an isomorphic JavaScript library (works in Node and in the browser) that provides a convenient API to access Wix Media Platform file upload service and image manipulation API.

Installation

npm install media-platform-js-sdk --save

Running the Demo

npm start

and goto http://localhost:3333/

Instantiating the Media Platform in the Server

First, if you haven't done so yet, register at Wix Media Media Platform, Once registered you'll be issued with your own API Key, API Secret and API Endpoint.

var MediaPlatform = require('media-platform-js-sdk').MediaPlatform;

var mediaPlatform = new MediaPlatform({
  domain: <as appears in the Dashboard>,
  apiKey: <as appears in the Dashboard>,
  sharedSecret: <as appears in the Dashboard>
});

File Upload

Server

var fileUploader = mediaPlatform.fileUploader;
var EncodingOptions = require('media-platform-js-sdk').video.EncodingOptions;
var MetadataDTO = require('media-platform-js-sdk').file.MetadataDTO;
 
var metadata = new MetadataDTO().addTags('cat', 'fish');
fileUploader.uploadImage(<ReadStream || Buffer || string path to file>, metadata || null, function (error, response) {

    if (error) {
      console.error('upload failed: ' + error.message);
      return;
    }

    console.log('upload successful: ' + response);
});

fileUploader.uploadAudio(<ReadStream || Buffer || string path to file>, metadata || null, function (error, response) {
    ...
});

fileUploader.uploadDocument(<ReadStream || Buffer || string path to file>, metadata || null, function (error, response) {
    ...
});

var encodingOptions = new EncodingOptions()
        .videoFormats(['mp4', 'webm', 'ogv'])
        .audioFormat('m4a');
fileUploader.uploadVideo(<ReadStream || Buffer || string path to file>, encodingOptions || null, metadata || null, function (error, response) {
    ...
});

Browser

File upload from the browser is a 2 step operation:

  1. First the signed URL and the upload token is retrieved from the server
  2. Then a multipart/form-data request is made to the URL

In the server expose a route that returns the signed URL and upload token:

app.get('/upload/:mediaType/credentials', function(req, res, next) {

    mediaPlatform.fileUploader.getUploadUrl(apiKey, req.params.mediaType,  function (error, urlAndToken) {

        if (error) {
            res.status(500).send(error.message);
            return;
        }

        res.send(urlAndToken);
    });
    
});

From the browser GET the URL and POST the form to it, including the token in the form body

<form id="upload-form" enctype="multipart/form-data" action="" method="post" target="upload-result">
    <input id="file" name="file" type="file" accept="image/*">
    <input id="media-type" name="media_type" type="text" value="picture" hidden>
    <input id="upload-token" name="upload_token" type="text" hidden>
</form>
<button id="upload-button">Upload</button>

<script>
    var button = document.getElementById('upload-button');
    button.addEventListener('click', function () {
        fetch('http://localhost:3000/upload/picture/credentials').then(function (response) {
            response.json().then(function (uploadCredentials) {
                var form = document.getElementById('upload-form');
                form.getElementsByTagName('upload_token').value = uploadCredentials.uploadToken;
                form.setAttribute('action', uploadCredentials.uploadUrl);
                form.submit();
        })
    })
})
</script>

Image Consumption

var ImageRequest = require('media-platform-js-sdk').image.ImageRequest;

var imageRequest = new ImageRequest('media.wixapps.net/wixmedia-samples/images', '000c45e21f8a433cb3b2483dfbb659d8', 'wow.jpeg');

var url = imageRequest.fit(500, 500).negative().saturation(-90).toUrl().url;

Documentation

For detailed capabilities and APIs go to the full documentation

Reporting Issues

Please use the issue tracker to report issues related to this library, or to the Wix Media Platform API in general.

Contributing

License

This library uses the Apache License, version 2.0.

About Wix

Wix.com is a leading cloud-based web development platform with more than 86 million registered users worldwide. Our powerful technology makes it simple for everyone to create a beautiful website and grow their business online.

About Google Cloud Platform

Google Cloud Platform enables developers to build, test and deploy applications on Google’s reliable infrastructure. It offers computing, storage and application services for web, mobile and backend solutions.