Release Notes

The following releases are available for the OpenShot Cloud API. It is recommended you use the most current release when starting up a new instance. See Upgrade instructions.

Latest

  • Unreleased

    • Fixing documentation to support markdown output (adding make markdown target, removing “|” from tables)

    • Adding many new sections to the documentation (pricing, load zip file, real-time previews, hardware acceleration, SSL config)

    • Adding timeouts for determine_cloud_environment function (so we don’t wait forever in non-cloud environments)

History

  • 3.1.0

    • New Schema generation for OpenAPI (3.0.3): /schema/ endpoint for Yaml schema file

    • Added /swagger-ui/ and /redoc/ to better document all available API endpoints. See Schema Documentation.

    • Large refactor of Schema related data (default values, argument names in routes, method descriptions)

    • Upgraded DRF framework to 3.15.1

    • Large refactor of Serializers (BaseSerializer & BaseModelSerializer)

    • Large refactor of “json” fields (to make them accept “strings” or {} objects), which results in less errors.

    • Stricter URL regex for IDs (must be integer in URL patterns). This was required for proper schema generation.

    • Refactored language codes into a common ENUM (for improved schema generation)

    • Fixed regression causing default values to not appear in web interface

    • New unit tests to verify duplicate file uploads do not crash

    • Protections around CopyFile serializer (prevent crashes in certain circumstances)

    • Protections around File.get_media() when using Cloud buckets and a missing “json” attribute

    • New environment variable to prevent OpenAI Whisper file permission errors

    • Refactored many unit tests, to use ‘json’ arg instead of ‘data’ arg (requests module)

    • Moved the following endpoints (grouping under /settings/ to clean-up API):

      • /aws/validate -> /settings/aws/validate

      • /azure/validate -> /settings/azure/validate

      • /google/validate -> /settings/google/validate

  • 3.0.3

    • Refactor QApplication initialization code and set XDG_RUNTIME_DIR to temp folder

    • Fixing regression which displays debug [ERROR] messages during the initial run of config-openshot-cloud

    • Improving config-openshot-cloud command to default CLOUD_HTTP_HOST to the public IP detected

    • Updating Google Cloud documentation, GCP marketplace URL, diagram, and instructions

  • 3.0.2

    • Adding Google Cloud Support (Pub/Sub & Cloud Storage integration, currently pending approvals for Google Cloud Marketplace)

    • Allow effects to be applied BEFORE or AFTER a clip’s keyframes (very useful for Mask effects, libopenshot C++)

    • Added auto-resize capability to Crop effect (to maximize the size of the cropped area in the video)

    • Improving Shutdown behavior of video processing worker script (handle SIGTERM signal correct, to cleanly and quickly shutdown any video rendering, and mark the export as failed)

    • Fixed audio pops in certain scenarios (when down sampling from 48000 to 44100 sample rate, libopenshot C++)

    • More verbose logging around webhooks, to document failures and make troubleshooting easier

    • Adding lock around SetCache method to prevent crash (libopenshot C++)

    • Fixed large memory leak on Clips where we were not clearing cache on Close or forcing Close on destruction (libopenshot C++)

    • Fixed caption parsing to better support numeric caption text (libopenshot C++)

    • Add additional logging to audio device initialization (libopenshot C++)

  • 3.0.1

    • Fixed multiple WEBM decoding issues (libopenshot would sometimes freezes or experience decoding artifacts with certain WEBM files)

    • Fixed bug causing audio-only clips to cover up images on lower tracks (i.e. audio clips were outputting a black opaque image)

    • Fixed regression with /info/fonts/ endpoint (permission issue when adding new fonts to /usr/share/fonts/)

    • Expanded list of installed font files (3.0.0 release had a limited # of fonts)

    • Fixing issue with bash history file (to correctly truncate for Azure technical validation)

  • 3.0.0

    • Added new /files/<id>/transcribe/ endpoint (powered by OpenAI Whisper AI) to transcribe voice and audio files. Can also translate transcription to English. Generates VTT/Subrip formatted caption text.

    • Added new /clips/<id>/captions/ endpoint, which adds VTT/Subrip formatted caption text to a Clip. This endpoint can also import transcription data from the related File object (if transcription data is available).

    • Improved time re-mapping (slow down, speed up - especially when using Bezier keyframes)

    • Improved audio reversing code (for playing videos in reverse)

    • Improvements to audio-only clip visualizations - which can now show waveforms and utilize Caption effects (for example, audio transcriptions on top of animated waveform)

    • Updates to default Caption Effect properties (smaller font size, smaller left/right margins). Also fixed many bugs with VTT/Subrip regular expression parsing - increasing compatibility with more caption data

    • Improved calculation for render update frequency - to use “time” instead of “frames”. This reduces the # of progress updates which happen during a render, especially for high FPS renders, reducing HTTP traffic. The setting SECONDS_BETWEEN_UPDATES is now defaulted to 3 seconds.

    • Updated supported image formats: .bmp, .dpx, .exr, .gif, .jpg, .jpeg, .pam, .pbm, .pcx, .pgm, .png, .pnm, .ppm, .psd, .sgi, .svg, .tga, .thm, .tif, .tiff, .webp, .xbm, .xpm, .xwd

    • Latest security patches and updates. Updated Django to 4.1.7, DFR to 3.14.0, and many other Python packages.

    • Fixed Zombie threads left behind after a video export, which over time can cause VM failures due to resource limits.

    • Large Memory Leak fixed after each video export is completed. This was causing an increase in RAM usage over time, and especially noticeable on higher resolution exports.

    • New Worker Clean-Up which removes old cached project assets on worker instances, after an export is completed. This ignores pending and in-progress exports. This can be disabled with a value of 0 (during configuration of instance).

    • New Automated Project Clean-Up which removes old projects after X days. This can be disabled with a value of 0 (during configuration of instance).

    • Improved cron schedule (new clean-up tasks, optimized schedule to reduce CPU and collisions)

    • New documentation regarding automated clean-up tasks. See Manage Server Files and Manage Worker Files.

    • Updated base OS to Ubuntu 22.04 Minimal LTS (Jammy)

  • 2.3.0

    • Async and PTS Timestamp improvements which fixes many bugs related to out-of-order frames, repeated frames, invalid durations, or missing frames at the beginning or end of a video file. This also dramatically improves performance on certain types of video/audio files that contain missing packets/frames.

    • Caption Improvements Many big updates to our Caption effect (including auto center alignment, background color now stays behind text, adjustable line spacing, and many bug fixes)

    • Improved Merging Fixed bug in /projects/<id>/merge/ endpoint, which prevented the original_merge_id from being added to merged clips and effects.

    • Removed Validation which prevented clips from being longer than their file’s duration. It is now completely valid to extend a clip past the file duration, and it will now freeze frame on the final frame (if needed) with muted audio.

    • Improved Text-Replace Fixed bug with /text-replace/ endpoint, to prevent file caching on distributed worker instances (i.e. the file name is now changed after calling this function)

    • Improved Export Failure Detection Added new statuses to the export process (preparing & finalizing) for more visibility into the export process, and with this additional context we have improved our detection of failures (which prevents accidental export failures).

    • Bug fix Actions (on Projects, Clips, Files, and Exports) now use the correct and current protocol (i.e. https vs http)

    • Bug fix /files/find/ endpoint has been fixed to correctly include embedded clip masks (this would fail previously on worker instances which could not locate the mask files)

    • Reduced Memory Usage By reducing the default QUEUE_MESSAGES_PER_SCRIPT setting from 12 to 4 (causing the render script to restart more often, clearing server memory)

    • Updates to documentation

  • 2.2.2

    • Memory improvements (i.e. reduced memory needed for Exports)

    • Memory leak fixed (when using longer 60+ min duration clips in different FPS than the project)

    • Auto Retry any Export which has been failed by a scheduled cron cleanup job (i.e. pending for too long, hard crash, cloud scaling termination). Only retires 1 time.

    • Launch of new Demo UI (simple-editor). MIT licensed, open-source, and a great jump-start to building your own custom web UI!

    • New Demos page included in the documentation

    • Fixed big regression with CORS support in v2.2.1 (moving from Apache to Python CORS support)

    • Improved Basic Auth: No longer return www-authenticate: Basic realm="api" response header if X-Requested-With request header is XMLHttpRequest. This prevents the web browser from prompting the user during 401 Basic auth failures when using XMLHttpRequest’s from the browser/JavaScript.

    • Cron jobs only run on instances configured as ‘server’ or ‘both’ (ignoring ‘worker’ instances)

    • Increasing # of foreign key values in dropdowns to 3000 (up from 1000), when using the default REST web UI.

    • Refactor how cloud environment is detected and loaded (development vs production)

    • New /tokens/ endpoint (to retrieve a token for a specific user)

  • 2.2.1

    • Fixed regression in config-openshot-cloud command (causing all custom username and passwords to be invalid)

  • 2.2.0

    • Updated Chroma Key effect to support new color modes (using babl color library) - Improving Chromakey quality in many cases.

    • Updated ReSVG library, for improved SVG compatibility and lots of quality of life updates for SVG rendering

    • Added new /exports/<id>/cancel/ endpoint, for canceling pending and in-progress video exports.

    • Updated worker script to process 12 videos before exiting (by default). The script will restart (to clear memory) after this happens.

    • Added support for a variety of export bitrate formats, instead of just bytes (7600000, 7.6 Mb/s, 7600 kb/s, 5 crf (0-63), 5 cqp (0-63), 20 qp (0-255))

    • Improved support for @transitions and @emojis in File and Clip paths.

    • Added support for all emojis in OpenShot 2.6.x (@emojis file paths will correctly resolve now)

    • Updated transition files (all transitions in OpenShot 2.6.x)

    • Added new /projects/<id>/download/format/ endpoint, for downloading offline EDL or XML (Final Cut Pro) project files

    • Fixed regression with copied projects rendering on worker instances (where some files could be located in the wrong folder)

    • Improved /files/find/ endpoint to only return unique files (improving performance on projects with many duplicate resources)

    • Updated libopenshot and libopenshot-audio libraries, improved performance

    • Fixed SCALE_NONE scaling bugs resulting in images that were too large (this was a regression in libopenshot)

    • Added Auto-Scaling Azure documentation (Scale Sets)

    • Adding many audio-only effects: (compressor, expander, distortion, delay, echo, noise, EQ, robot, whisper)

    • Fixed config-openshot-cloud issue on Azure, which would not disable the worker process on a server instance (causing the worker to continue processing exports on the server)

    • Block most signals from triggering on upgrade (i.e. loaddata)

    • Improved error logging on worker / video processing script

    • Improved documentation for manually upgrading between API versions

    • Migration helper script for older API customers (migrating from an older DB schema)

    • Improved thumbnail endpoints, which correctly size thumbnails to the requested dimensions.

    • Fixed small bug in /files/ID/download endpoint, where certain file names were incorrectly escaped

    • Removing redundant call to /exports/ID/ on worker script (small performance improvement)

    • Webhooks are now sent with application/json content-type by default (instead of form-urlencoded). Legacy support can be toggled (for application/x-www-form-urlencoded if needed by including "json": { "webhook-form-urlencoded": true} in your export record).

    • Failed exports will now include an error message in the Export record: "json": { "error": "Something went very wrong!"}

    • Clips with time keyframes no longer validate the end property (i.e. it can be longer than the duration in these cases)

    • Improved unit tests to ensure better quality and to verify all bug fixes

    • Fixed PATCH CORS error, where certain policies would prevent PATCH from working

  • 2.1.1

    • Fixed regression with audio-only exports (now both video and audio exports support mp4_faststart)

    • Updated documentation related to aac audio codecs

    • Updated list of available effects (to dynamically list all libopenshot effects)

    • Added support for HTTPS load balancers (HTTP_X_FORWARDED_PROTO)

  • 2.1.0

    • Massive performance improvements in video compositing, encoding, and decoding processing

    • Audio crackling/popping fixes on libopenshot, which affected certain sample rate and frame rate conversions.

    • Audio crash fixed which would cause certain channel layout (i.e. MONO) to freeze and crash.

    • Added a C# example script in the getting_started section

    • Added /projects/<id>/merge/ endpoint for combining two projects. This is especially useful for combining template projects.

    • Exif support for most image formats (auto-rotation)

    • Support for Captions effect (single VTT/subrip string which can display text through-out a video, including animation)

    • Updated libopenshot and libopenshot-audio libraries, improved performance (pre-multiplied alpha channels)

    • Improved support for videos containing an alpha channel

    • Added interlaced and top_field_first Export json attributes (that can be overwritten)

    • mp4_faststart enabled for video exports (moov atom is located at the beginning of the file) to enable streaming

    • Fixed bug when webhook url called contains localhost/private IP instead of public http host

    • Added logging to all cases in which os.unlink is called

    • Added validations to /clips/ POST, PUT, AND PATCH endpoints, to ensure clips do not exceed the file duration, and other common issues

  • 2.0.0

    • Introduced the concept of shallow copy (physical media file is not duplicated) in files

    • Improved support for nested Clip effects and effect paths, including /validate/, /download/, and /load/ improvements related to clip effects.

    • /project/ID/copy/ and /files/ID/copy endpoint by default perform a shallow copy

    • For performing PUT PATCH DELETE on /files/ID/ endpoint, project is now a required parameter for files being shared in more than one projects

    • Introduced the /projects/ID/files/ID/ endpoint that supports GET PUT PATCH DELETE

    • To update a file for all projects sharing the file, pass update_all=true as a query string parameter in the PUT PATCH DELETE methods on /file/ID/. User must have access to all of the related projects

    • When PUT PATCH is executed on either /files/ID/ (with project param) or /projects/ID/files/ID/ on an file that is being shared by more than one project, a new file object is created and the previous file is de-referenced from the project.files

    • With this change, it is possible for files of one project to exist in the folder of another project (even deleted projects)

    • Refactored signals into a new file

    • Improved stability, and many new unit tests to ensure quality

  • 1.3.0

    • Full support for image sequences (with transparency), such as Blender animations, animated overlays, etc… * /cloud-admin/ is now a fully supported environment, allowing full API functionality from the Admin.

    • Added /storage/ endpoints for calculating size of files and projects (/files/<id>/storage/ and /projects/<id>/storage/)

    • Added ability to mirror all API media files in cloud storage (so the API server can remove local files and re-download them when needed)

    • Fixed many bugs related to saving/uploading/changing media files for File objects

    • Added improved ability to use local Django models with custom applications

    • Improved testing, automation, and quality improvements

    • Updated verbiage and images for Azure support (including new documentation pages)

    • Fixed bug which marked almost completed (>99% progress) exports as failed

    • Fixed bug in /projects/ID/copy/ endpoint, which prevented the copying of custom effect masks

    • Fixed bug when loading a *.zip containing a __MACOS hidden folder

    • Fixed bug in orphaned file clean-up, which would delete custom effect masks

    • Fixed bug with OPTIONS configuration (was throwing error)

    • Fixed bug with config-openshot-cloud resetting the wrong superuser account password

    • Fixed bug where S3 uploads had incorrect/no content-type set

    • Added documentation for storage scaling support (Amazon Elastic File System: EFS)

  • 1.2.3

    • Added retry logic for download files from URL or S3 (when creating File objects)

    • Added retry logic when inspecting newly uploaded File objects

    • Improved error handling and logging when invalid or corrupted File objects are used

    • Added secure download endpoints for media files (/files/<id>/download/ and /exports/<id>/download/)

    • Workers now fallback to secure download endpoints, if direct media URLs are invalid (i.e. if you manually disable them in Apache for security)

    • Added new configuration setting to override HTTP_HOST (and force all URLs to use any public URL you want). This is especially useful for webhooks (which often refers to http://127.0.0.1).

    • Improvements to config-openshot-cloud command, messages, formatting, AWS/Azure cloud detection, and support for Azure cloud backend (Queue and Blob storage)

    • Added Azure Blob Storage support to File and Export endpoints (Exports can support both S3 and Azure Blob storage concurrently)

    • Added Azure Queue Storage support for Export queue management (OpenShot API now supports both SQS or Azure Queues… just not at the same time)

  • 1.2.2

    • Improved /files/<id>/copy/ endpoint, which now has an optional “project” parameter. This can be used to copy a file to a different project.

    • Much improved config-openshot-cloud command (formatting and layout improvements, ability to register for support)

    • Fixed Effect (Mask) bug where workers were not able to download a custom asset

    • Added new unit tests with more coverage and many additional edge cases handled

    • Upgraded libopenshot C++ library with latest improvements and bug fixes (including a serious SVG mask related bug)

    • Experimental hardware acceleration support in libopenshot (requires instances with hardware encoders/decoders)

    • More reliable asset downloading between workers and server (retry logic and improved error reporting)

    • Enable CORS (cross-origin resource sharing) by default (can be disabled in /etc/apache2/sites-available/openshot.conf)

    • Upgraded boto3 module, for improved AWS S3/SQS support (added support for more regions: ap-south-1)

    • Updated system libraries and applied security updates

    • Improved documentation (REST methods, frame # calculations, suggested instance types, upgrade instructions)

  • 1.2.1

    • Fixed regression with /files/<id>/copy/ endpoint, where original file media was removed

    • Fixed regression with /projects/<id>/copy/ endpoint, where original file media was removed

    • Improved documentation for token authentication

  • 1.2.0

    • Upgrade from Ubuntu 16.04 LTS to 18.04 LTS

    • All libraries and frameworks updated (including Qt, FFmpeg, resvg, and Python)

    • Improved SVG rendering (due to updated Qt dependency)

    • Fixed SVG right alignment bug (due to updated Qt dependency)

  • 1.1.1

    • Much improved SVG rendering (using resvg library). Supports more of the SVG language than our previous Qt SVG library.

    • Fixed bug with export object, where webhooks and S3 options were being clobbered at the end of an export.

    • Fixed S3 upload failures

    • Added more unit tests to validate S3 uploading and webhooks

    • Added new /info/fonts/thumbnail/ endpoint, to preview all installed fonts

    • New default font, when the API can not find an installed font

  • 1.1.0

    • Replaced ZMQ queue with AWS SQS (for more reliable and scalable queue handling of video exports). Requires IAM user and permissions (AmazonSQSFullAccess & AmazonS3FullAccess).

    • Worker queue processing now restarts after exports are complete (clearing memory)

    • Worker file synchronizing is much faster (and more optimized)

    • Fixed /projects/<id>/load/ endpoint bug when loading ZIP archive of project files.

    • New /info/fonts/ endpoint for adding new Font files dynamically (POST method now accepted)

    • Memcached replacing local memory caching (more efficient caching)

    • /projects/<id>/files/find/ endpoint has been modified, to provide the media URL and file object URL

    • Updated documentation with new AWS SQS instructions

  • 1.0.10

    • Improved API performance (less DB queries per request)

    • File updating bug fix (updating the media of a file would break)

    • New libopenshot version (fixes some codec issues, improved performance, better detection of various media formats)

  • 1.0.9

    • Added /files/<id>/copy/ endpoint to Project and File objects

    • Added /projects/<id>/download/ endpoint for projects (ZIP archive of entire project with relative paths)

    • Added /files/<id>/text-replace/ endpoint for File objects (for easily editing SVG or text-based files)

    • Improved /projects/<id>/load/ endpoint to optionally accept a ZIP archive of an entire project with media files

    • Improved detection of installed AAC encoders

    • Improved speed of many endpoints (by reducing # of SQL queries and caching)

    • Reduced default video bitrate, for smaller files by default

    • Changed /projects/<id>/title/ endpoint to return the new file JSON (instead of a 302 redirect)

    • Allow OPTIONS method without authentication (for CORS)

    • Fixed webhooks for pending and failed exports

    • Fixed UTF-8 encoding error with unicode fonts (also added Noto fonts, including Japanese font)

    • Maintain original_id when /load/ endpoint is used

    • Added new unit tests for more coverage of API endpoints

    • Updated documentation with new endpoints

  • 1.0.8 - Updated libopenshot version (fixed volume keyframe regression), and misc library improvements / fixes

  • 1.0.7 - Reverting to libfdk_aac for AAC support. New native S3 support (for File and Export objects). Duplicate files on PUT or PATCH bug fixed. Improved file-system clean-up. Also improved docs with new S3 examples, and added upgrade instructions and release notes.

  • 1.0.6 - Improved Audio Support (AAC), Better Memory Management, Misc Bug Fixes

  • 1.0.5 - Stability Improvements, New Presets, Improved Docs

  • 1.0.4 - Improved Webhooks, Improved Docs, Improved Logging, Misc Bug fixes

  • 1.0.3 - Title Endpoints, Improved Docs, Misc Bug fixes

  • 1.0.2 - Improved Performance, Improved Stability

  • 1.0.1 - Stability Improvements, Misc Bug Fixes

  • 1.0.0 - Initial Release of OpenShot Cloud API