Magnus von Wachenfeldt
Aug 20, 2010
  11793
(6 votes)

EPiServer and streaming video in ten minutes

Customers asking for streaming video are becoming increasingly prevalent. I will make this short; Nansen to the rescue!

I set out to create a module that is easy to deploy with support for uploading, removing, editing and linking videos from the EPiServer UI. After searching around for streaming video providers I decided Viddler would suit my needs since they have an awesome fourth point on why I should use it on http://developers.viddler.com/.

So, let’s see what this module can do.

When you configure the VirtualPathProvider you will get a new Viddler folder in your file manager.

deleted_wildlife

Since we’re speaking with the Viddler API you can upload directly into your Viddler account from the EPiServer UI.

uploadvideo1

Let’s click save…

uploaded_wildlife

Awesome! What can I do with this?

video_selector

Why, you can use the included specialized property to put it on your pages of course.

embedded_video

…or you can link to it with the default link tool and get a full screen video.

link

 

You just need to create an account on Viddler, put the assembly in your bin folder and add the following to web.config.

 

This should go under your configSections. Modify according to what your configSections look like.

   1: <sectionGroup name="applicationSettings" type="System.Configuration.ApplicationSettingsGroup, System, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
   2:   <section name="Nansen.Viddler.Properties.Settings" type="System.Configuration.ClientSettingsSection, System, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
   3: </sectionGroup>

Add this to your virtualPath/providers section.

   1: <add showInFileManager="true" virtualName="Viddler" virtualPath="/Viddler/" customFileSummaryPath="/ViddlerFileSummary.config" bypassAccessCheck="true" name="ViddlerFiles" type="Nansen.Viddler.Hosting.ViddlerVirtualPathProvider, Nansen.Viddler" />

Copy this into your applicationSettings section and modify according to your Viddler account information.

   1: <Nansen.Viddler.Properties.Settings>
   2:     <setting name="ApiKey" serializeAs="String">
   3:         <value>0123456789abcdef0123456789abcdef0123</value>
   4:     </setting>
   5:     <setting name="ApiUrl" serializeAs="String">
   6:         <value>http://api.viddler.com/rest/v1/?method={0}&amp;api_key={1}</value>
   7:     </setting>
   8:     <setting name="Username" serializeAs="String">
   9:         <value>yourUsername</value>
  10:     </setting>
  11:     <setting name="Password" serializeAs="String">
  12:         <value>yourPassword</value>
  13:     </setting>
  14:     <setting name="SizePresets" serializeAs="String">
  15:         <value>Default;437;370|Viddler;545;451</value>
  16:     </setting>
  17: </Nansen.Viddler.Properties.Settings>

We will also need a handler for the full screen links.

   1: <location path="Viddler">
   2:   <system.webServer>
   3:     <handlers>
   4:       <add name="Viddler" path="*" verb="GET" type="Nansen.Viddler.Hosting.ViddlerHttpHandler, Nansen.Viddler" preCondition="integratedMode" />
   5:       <add name="wildcard" path="*" verb="*" type="EPiServer.Web.StaticFileHandler, EPiServer" />
   6:     </handlers>
   7:   </system.webServer>
   8:   <staticFile expirationTime="-1.0:0:0" />
   9: </location>

 

Known bugs

* Multiple videos with the same name is not supported, but easily fixed

* Tagging is not working properly

* File size not showing up in UI (no support in API, not really relevant anyway)

Beware of hacky code.

Happy uploading!


Aug 20, 2010

Comments

Sep 21, 2010 10:33 AM

I will show this at our EPiServer Techforum in Norway on September 8th. Nice for demo use...

Sep 21, 2010 10:33 AM

I am honoured! Please tell me how everything worked out.

Lars Bodahl
Lars Bodahl Sep 21, 2010 10:33 AM

Stein-Viggo demoed this on the Techforum yesterday. Looks good! :-)

Sep 21, 2010 10:33 AM

Awesome! And thank you. :)

Annio Cavuoto
Annio Cavuoto Apr 12, 2011 01:41 PM

Great, thank you :)

Jan Montano
Jan Montano Jun 2, 2011 08:30 AM

That looks really promising. Where can you actually download the assembly from?

I looked at Nansen site and I must admit I got a little bit lost there.

Please login to comment.
Latest blogs
Creating an Optimizely CMS Addon - Adding an Editor Interface Gadget

In   Part One   of this series, I covered getting started with creating your own AddOn for Optimizely CMS 12. This covered what I consider to be an...

Mark Stott | Aug 30, 2024

Configure your own Search & Navigation timeouts

The main blog Configure your own Search & Navigation timeouts was posted for years but you need copy the code to your application. We now bring tho...

Manh Nguyen | Aug 30, 2024

Joining the Optimizely MVP Program

Andy Blyth has been honoured as an Optimizely MVP, recognising his contributions to the Optimizely community. Learn how this achievement will enhan...

Andy Blyth | Aug 29, 2024 | Syndicated blog

Welcome 2024 Summer OMVPs

Hello, Optimizely community! We are thrilled to announce and welcome the newest members to the Optimizely Most Valuable Professionals (OMVP) progra...

Patrick Lam | Aug 29, 2024

Create custom folder type in Edit Mode

Content Folders, which are located in assets pane gadget or multichannel content gadget, allow you to add any type of block or folders. But...

Grzegorz Wiecheć | Aug 28, 2024 | Syndicated blog

Creating an Optimizely AddOn - Getting Started

When Optimizely CMS 12 was launched in the summer of 2021, I created my first AddOn for Optimizely CMS and talked about some of the lessons I learn...

Mark Stott | Aug 28, 2024