Skip to main content

A registry and adapters for converting urls for various video sharing sites into embed codes.

Project description


A registry and adapters for converting urls for various video sharing sites into embed codes.

This package provides some functions and zope3 components for converting urls from common streaming video sites into embed codes. The purpose is to allow for content types that provide a user entered url to display embeded video based on that url. This is to avoid allowing users to enter raw html embed codes which is potentially dangerous and cumbersome. It also allows for dynamic scaling of the generated embed code to fit with your page layout.


At the heart of this product is a set of named adapters. These adapters adapt a string (url) and an integer (width) and return a unicode embed code. Currently, adapters are provided for the following video sharing sites:

But adding more is as simple as creating a function that checks if the url is appropriate for the site you want, and another to convert it into an embed code. You register the latter function as a named adapter, like:

    for="str int"

And register the url checking function as a utility with the same name:

    name="youtube" />

You may optionally provide an integer ‘index’ as an attribute of the checker to determine the relative order in which the check is made (more specific checks should go earlier).

Getting the Embed Code

There are a couple ways to generate an embed code, depending on your usecase. The easiest is single adaptation of a url:

from p4a.videoembed.interfaces import IEmbedCode embed_code = IEmbedCode(url)

This gives an embed of a preset width (425px), to get a custom width, you multiadapt:

from zope.component import getMultiAdapter embed_code = getMultiAdapter((url, width), IEmbedCode)

There is also a convenient view provided for use from restricted code, it optionally takes a url and width and returns an embed code. If the url is omitted, then it will try and get one from the context by adapting to ILinkProvider (which indicates the presence of a getLink method).

<div class="EmbedCode"
     tal:define="embed_view nocall:context/@@video-embed.htm;
                 default_embed embed_view;
                 custom_width python:embed_view(width=500);
                 custom_url python:embed_view(url='', width=250)"
     tal:replace="structure default_embed" />

This shows how you can use the view from tal to generate a url from an object that implements or is adaptable to ILinkProvider, or using an explicit url from any object.

In all of these methods the adapter checks the global utility that the named adapters are registered with and finds the appropriate one for the given url.

I hope you find this useful.

Author: Alec Mitchell <> Sponsor: The Daily Reel

Changelog for videoembed

videoembed - 1.2 (2009-05-17)

  • fix ComponentLookupError import from zope.component [toutpt]

  • removed unused imports reported by pyflakes [tom_gross]

  • add partial Dailymotion support [toutpt]

videoembed - 1.1 (2008-04-09)

  • added Brightcove support [Nate Aune]

videoembed - 1.1b1 (2008-02-14)

  • added partial support [Rocky Burt] r1672

  • added code to extract URL to FLV file from Youtube and (Ross Patterson) r1875 and r1879

videoembed - 1.0alpha1 (2007-04-29)

  • Initial public release. [Rocky Burt]

videoembed - 0.1 (unreleased)

  • Initial package structure. [zopeskel]

Project details

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution (44.0 kB view hashes)

Uploaded source

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page