Skip to content


Subversion checkout URL

You can clone with
Download ZIP
oEmbed consumer library for node.js & tools
Latest commit cd1b440 @astro Merge pull request #5 from focusaurus/use-pipe-instead-of-pump
migrate deprecated util.pump to readableStream.pipe.



oEmbed is a format for allowing an embedded representation of a URL on third party sites. The simple API allows a website to display embedded content (such as photos or videos) when a user posts a link to that resource, without having to parse the resource directly.

This library allows you to discover and retrieve the oEmbed JSON descriptors for these posts. It automatically converts the additional XML format to JavaScript objects for your convenience. This package comes with multiple tools that allow you to consume oEmbed information.


npm i oembed

Don't forget to put it in dependencies of your package.json later if you use this in a node app.


  • Supports both

    • application/json+oembed
    • text/xml+oembed
  • Automatic fallback when an API key is provided

  • Uses htmlparser for HTML and XML parsing

Tools (bin/)

oembed_get <URL>

Retrieve and display oEmbed information for a custom URL.

oembed_httpd <bind-port> [bind-host]

Replicates the API in a simple Web server.

oembed_diff_json_xml <URL>

Compare JSON and XML descriptors for a URL.

API (require('oembed'))

In a real-world app all you should need is the fetch function to get oEmbed information. We always use the function callback(error, result) convention.

oembed.fetch(url, { maxwidth: 1920 }, function(error, result) {
    if (error)
        console.log("oEmbed result", result);

The two steps can be executed separately whenever you need more control:

  •, callback) finds all <link rel="alternate"> in a document
  • Get and parse descriptors immediately with oembed.fetchJSON(url, callback) and oembed.fetchXML(url, callback) if you have discovery information already fallback

The service can deliver oEmbed information even for resources that don't provide oEmbed links. Go sign up with them and configure your API key like:

oembed.EMBEDLY_KEY = "...";


  • Document size limits?
  • bin/oembed_httpd: Multiple URLs like
  • bin/oembed_httpd: Pass through for ETags and Last-Modified
Something went wrong with that request. Please try again.