npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@sugarcube/plugin-media

v0.42.1

Published

Media related plugins.

Downloads

59

Readme

SugarCube media plugin

Operations on media files and URL's.

Installation

npm install --save @sugarcube/plugin-media

Plugins

media_exif

Extract exif data from image urls in _sc_media fields.

sugarcube -c config.json -q queries.json -p google_images,media_exif

media_youtubedl

Download all videos of type video that are stored in _sc_media. SHA256 and MD5 sums are calculated for those downloads. It also downloads thumbnails and subtitle files if available. The plugin uses the external youtube-dl program to actually download. This makes it compatible with a variety of websites.

Configuration Options:

  • media.data_dir: Download all videos into this directory. Defaults to data.
  • media.download_format: Download videos in this video format. Defaults to mp4.
  • media.youtubedl_cmd: The path to the youtube-dl command. Defaults to youtube-dl, with no specific path supplied.
  • media.youtubedl_parallel: Specify how many videos to fetch at the same time. It defaults to 1 and can be set between 1 and 8.
  • media.youtubedl_force_download: Set this flag to true for force a download of the video, even if it already exists.
  • media.youtubedl_delay: Wait between invocations of youtube-dl for DELAY <= N < 2xDELAY seconds. Defaults to 0 seconds.
  • media.youtubedl_source_addresses: Bind youtube-dl to the one or more source IP address. If there are more than one addresses, balance in a round robin fashion. Defaults to the default route of the host.
{
  "media": {
    "youtubedl_source_addresses": ["192.168.2.100", "192.168.2.101"]
  }
}

Example:

$(npm bin)/sugarcube -q queries.json -c config.json -p twitter_feed,media_youtubedl

Metrics:

  • total: The total number of videos downloaded.
  • existing: The number of videos that already existed.
  • fail: The number of videos that failed to download.
  • success: The number of videos that were successfully downloaded.

media_youtubedl_check

Check any video in `_sc_media** if it is still available.

Configuration Options:

  • media.youtubedl_cmd: The path to the youtube-dl command. Defaults to youtube-dl, with no specific path supplied.
  • media.youtubedl_parallel: Specify how many videos to fetch at the same time. It defaults to 1 and can be set between 1 and 8.
  • media.youtubedl_delay: Wait between invocations of youtube-dl for DELAY <= N < 2xDELAY seconds. Defaults to 0 seconds.
  • media.youtubedl_source_addresses: Bind youtube-dl to the one or more source IP address. If there are more than one addresses, balance in a round robin fashion. Defaults to the default route of the host. Set it to an array of IP addresses in a JSON config file.
{
  "media": {
    "youtubedl_source_addresses": ["192.168.2.100", "192.168.2.101"]
  }
}

Metrics:

  • total: The total number of videos checked.
  • fail: The number of videos that failed to check.
  • success: The number of videos that were successfully checked.

media_mosaic

Generate a mosaic of screenshots for every video in _sc_downloads. This plugin will create a mosaic.jpg in the same download directory as the video. The mosaic can be generated either based on scene changes or every 400th frame. The mosaic is generated using [ffmpeg](https://www.ffmpeg.org/**.

Configuration Options:

  • media.ffmpeg_cmd: The path to the ffmpeg command. Defaults to ffmpeg.
  • media.mosaic_parallel: Specify how many mosaics are generated in parallel. It defaults to 1 and can be set to a value between 1 and 8.
  • media.mosaic_force: Unless set to true this plugin will skip generation if a mosaic already exists. Defaults to false.
  • media.mosaic_strategy: Choose the strategy to be used when generating mosaics. Can either be scene-change to generate mosaics based on scene changes in the video, or nth-frame to sample screenshots every 400th frame. Defaults to scene-change.

Example:

$(npm bin)/sugarcube -p youtube_video,media_youtubedl,media_mosaic \
                     --media.mosaic_strategy nth-frame \
                     --media.mosaic_force

Metrics:

  • total: The total number of video mosaics generated.
  • existing: The number of mosaics that already existed.
  • fail: The number of mosaics that failed to generate.
  • success: The number of mosaics that were successfully generated.
  • new: The number of new mosaics out of the number of successfully generated mosaics.

media_file_import

Import media files into the data collection. This plugin works with the fs_import plugin.

Configuration Options:

  • media.data_dir: Import all videos into this directory. Defaults to data.
  • media.import_video_format: Import videos in this video format. Defaults to mp4.
  • media.ffmpeg_cmd: The path to the ffmpeg command which is used to import videos. Defaults to ffmpeg, with no specific path supplied.
  • media.import_parallel: Specify how many files to import at the same time. It defaults to 1 and can be set between 1 and 8.
  • media.force_import: Set this flag to true for force an import of the file, even if it already exists.
  • media.keep_original: If set to true, make a copy of the original file as well. The original is copied as is, without any transformation. Defaults to false.

Example:

$(npm bin)/sugarcube -Q glob_pattern:~/files/* -p fs_import,media_file_import

Metrics:

  • total: The total number of files imported.
  • existing: The number of files that already existed.
  • fail: The number of files that failed to import.
  • success: The number of files that were successfully imported.
  • new: The number of new files out of the number of successfully imported files.

media_warc plugin

Archive media of type url as a gzipped WARC file.

Configuration Options:

  • media.data_dir: Archive all URL's into this directory. Defaults to data.
  • media.warc_force_download: Set this flag to true for force a archival of the URL, even if it already exists.
  • media.warc_parallel: Specify how many websites to archive at the same time. It defaults to 1 and can be set between 1 and 8.

Example:

$(npm bin)/sugarcube -q queries.json -c config.json -p http_import,media_warc

Metrics:

  • total: The total number of URLs archived.
  • existing: The number of URLs that already existed as an archive.
  • fail: The number of URLs that failed to archive.
  • success: The number of URL's that were successfully archived.
  • new: The number of new archives out of the number of successfully archived URL's.

media_screenshot

Take a screenshot of every URL in _sc_media and populate the _sc_downloads field with the location of the images. The format of the screenshot is JPEG. Screenshots are stored in <data_dir>/<unit id>/screenshot/screenshot-<media id>.jpg.

Configuration Options:

  • media.data_dir: Store all screenshots into this directory. Defaults to data.
  • media.force: Force a new screenshot, even if one already exists at the target location.
  • media.parallel: Specify how many screenshots to take at the same time. It defaults to 1 and can be set between 1 and 8.

Example:

Import some websites and take screenshots of them.

$(npm bin)/sugarcube -q queries.json -p http_import,media_screenshot

Metrics:

  • total: The total number of screenshots taken.
  • existing: The number of screenshots that already exist.
  • fail: The number of screenshots that failed.
  • success: The number of screenshots that were successfully taken.
  • new: The number of new screenshots out of the number of successfully taken screenshots.

media_fetch

Fetch images and documents from _sc_media. Downloaded targets are added to the _sc_downloads collection. To fetch videos use the media_youtubedl plugin.

Configuration Options:

  • media.data_dir: Specify the target download directory. Defaults to ./data.
  • media.fetch_types: Fetch files of this media type. Separate different types using a comma. Defaults to "image,document".

Metrics:

  • total: The total number of files fetched.
  • existing: The number of files that were already previously fetched.
  • success: The number of files that were successfully fetched.
  • fail: The number of files that failed to fetch.
  • new: The number of new files out of the number of successfully fetched files.

License

GPL3 @ Christo