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 🙏

© 2025 – Pkg Stats / Ryan Hefner

crabsave

v1.5.2

Published

Yet Another UGC Downloader With GUI

Downloads

33

Readme

CrabSave | Yet Another UGC Downloader With GUI

CrabSave is a B/S application to download UGC (User-generated content) from several sites, mainly focus on media contents. With features like multitasking, breakpoint resume, and download history management.

Index

Installation

You could use CrabSave as a CLI tool

npm i -g crabsave

You could also use it programmatically

npm i crabsave

Usage

To use from CLI command

crabsave [-p ${Port to deploy the web server}] [-d ${Path to store settings}]

crabsave -h # for help

# Example
crabsave -p 8000

Or use it programmatically

const CrabSave = require('crabsave')

CrabSave(
{
	PortWeb? : 8000,
	Data? : 'Path to an existing directory'
})

And then a local web server localhost:8000 will be deployed and can be visited from browsers (that support WebSocket). We involve a simple Token facility here to ensure that only the owner can operate, and you can find the initial token in the Data Folder

API

CrabSave(Option)

  • Option : Object
    • PortWeb : number Optional. Port to deploy the Web Server.
    • Data : string Optional. Path to store settings and databases. See Data Folder Structure
    • GoogleAPIKey : string Optional. Your own Google API Key in case the bundled key exceeds the call limits.
  • Returns : Object

Manual

Basic usage

The basic usage would be like

  • Paste the link or type in the keywords
  • Select posts by clicking their cover images to download or Ctrl+a to select all shown posts, where selected posts could be viewed from the Cold list
  • Commit tasks from the Cold list to the Hot list to start downloading

Check folder Site for supported sites

Keyword input

We support multiple ways to locate the posts to download here

  • Enter the link of the post (eg. https://www.youtube.com/watch?v=kobvF5cs6xY)
  • Enter the link of the uploader (eg. https://www.youtube.com/user/ChromeDevelopers, https://www.youtube.com/channel/UCnUYZLuoy1rq1aVMwx4aTzw)
  • Enter keyword command (eg. YouTube kobvF5cs6xY, YouTube User ChromeDevelopers, YouTube Channel UCnUYZLuoy1rq1aVMwx4aTzw)
  • There are also several aliases for some supported sites, which means you can type it shorter (eg. Y kobvF5cs6xY, y uSer ChromeDevelopers, y channel UCnUYZLuoy1rq1aVMwx4aTzw)
  • As you may notice from examples above, site names and command names are case insensitive.
  • Providing Cookies will unlock more to do for each site (eg. y subscription or simply y to view the list just the same as browsing https://www.youtube.com/feed/subscriptions, y fo to view subscribed channels)
  • We also embedded the searching feature since the input looks like those search bars (eg. y find love will ask YouTube to search for contents related to love)

File name format

The default format is |Up|.|Date|.|Title|?.|PartIndex|??.|PartTitle|??.|FileIndex|?
Where |FieldName| will be replaced by its value. ?OptionalPart? only effects if all FieldName it contains exist.
All available fields are shown below |Field|Description| |---|---| ||ID||ID of a post| ||Site||Site of a post| ||Title||The title| ||Up||Name of the uploader or channel| ||Y||The year of the created date (in local timezone)| ||M||The month of the created date (in local timezone)| ||D||The day of the created date (in local timezone)| ||H||The hour of the created date (in local timezone)| ||N||The minute of the created date (in local timezone)| ||S||The seconds of the created date (in local timezone)| ||Date||Shortcut of |Y|.|M|.|D|.|H|.|N|.|S|| ||PartIndex||(Optional) The index of a subpart counted from 0| ||PartTitle||(Optional) The title of a subpart| ||FileIndex||(Optional) The index of a file in a part, counted from 0. It will be null when all files in a part having different extension (specially for DASH videos)| ||Type||(Optional) Meta for metadata, Cover for cover image, otherwise null|

Misc

Data Folder Structure

Default location
Windows %AppData%/ZED/CrabSave
Unix $HOME/.local/share/ZED/CrabSave
Mac $HOME/Library/Preferences/ZED/CrabSave

ZED/CrabSave
+-- Key # The authorization token, randomly generated on the first run
+-- DB.db # The database of tasks
+-- Setting.json
+-- ShortCut.json
+-- Cookie.json # Cookie settings
+-- Web.js # Bundled script for Web clients

Changelog

v1.5.0 Beaking Changes

From this version, the protocol between C/S has been revamped, thus browsers running old version pages will not be able to communicate with newer versions.

v1.4.0

From this version, we do NOT ONLY focusing on video or audio data, we also supported to save infomation related to posts including Metadata and Cover Images. Also, posts without video or audio (eg. text only) are able to be saved now.

Updates from V0

The current version is a rewrite of the previous version (on branch V0) with few major differences

  • Drop the usage of Electron and publish it as an NPM package. We find out that it is not necessary to involve a desktop application. Separating to B/S makes it easy to initiate downloads remotely
  • Use SQLite3 instead of NeDB. NeDB is a nice DB choice, but since it won't compress its journal, we switch to SQLite3 instead. The disk usage is pretty the same, for 32000+ tasks, their file sizes are both around 52MB

Examples

Example : Custom Web Server

Required dependencies

npm i express

Then

const CrabSave = require('crabsave')
const Express = require('express')
const HTTP = require('http')
const WS = require('ws')

const Save = CrabSave({...})
const Exp = Express().use('/Play',Save.Exp())
const Server = HTTP.createServer(Exp).listen(8000)
new WS.Server({server : Server,path : '/Play/'})
	.on('connection',Save.Soc)

And now you can visit from localhost:8000/Play