Cloudflare Stream
This plugin offers a easy way to upload your videos assets from Craft CMS to Cloudflare stream.
Installation:
1) Install with composer
composer require deuxhuithuit/craft-cloudflare-stream
2) Install in craft
craft plugin/install cloudflare-stream
3) Add your account id and api token in the settings.
4) Create a video stream Field and add it to your Asset data model.
5) When editing an asset, you can now opt-in into sending videos in Cloudflare Stream.
6) If your are using twig, with a field named stream
you can access the stream data like so:
{% set value = asset.stream %}
<video controls style="width: 100%" poster="{{ value.thumbnail }}">
{% if value.mp4Url %}
<source src="{{ value.mp4Url }}" type="video/mp4">
{% endif %}
{% if value.playback.hls %}
<source src="{{ value.playback.hls }}" type="application/x-mpegURL">
{% endif %}
{% if value.playback.dash %}
<source src="{{ value.playback.dash }}" type="application/dash+xml">
{% endif %}
</video>
7) If you are using graphql, there is a type registered to make it easy to request the proper data.
query MyQuery {
asset(site: ["en"], volume: "stream") {
url
kind
extension
filename
... on stream_Asset {
videoStream {
uid
name
size
thumbnailTimestampPct
thumbnail
preview
hls
dash
mp4
watermark {
uid
created
downloadedFrom
height
name
opacity
padding
position
scale
size
width
}
input {
width
height
}
}
}
}
}
This extension uses Craft's Queue system, so make sure it works properly.
Made with ❤️ in Montréal.
(c) Deux Huit Huit
Standard
Plus $19/year after one year.
To install this plugin, copy the command above to your terminal.