rawdl
v1.1.13
Published
A script that automates seasonal anime downloads sourced from SubsPlease
Downloads
37
Readme
RawDL💮
This package allows for easy scheduled seasonal anime download and subsequent upload.
Installation
Use npm to install the package.
npm i rawdl
Usage (NodeJS)
See /examples/js for more use cases.
The following instructions help you set up a directory with shows.json file and JS Script to download and upload new episodes.
- Create a valid shows.json file. eg: (examples/js/shows.json)
{
"list": [
{
"name": "Horimiya",
"nextEp": 4,
"day": 0
}
]
}
- Create a JS or TS script to run the package AutoPilot. eg: (examples/js/index.ts)
//Typescript
import { rawdl } from 'rawdl';
var dirname = __dirname;
const api_keys = {
username: '<<your api username here>>',
password: '<<your api key here>>',
folder: '<<your api folder id here>>'
};
async function auto() {
//Params (shows.json, SubsPlease RSS Feed, Streamtape API Keys, Output Folder);
let ap = new rawdl.AutoPilot(dirname + '/shows.json', 'https://subsplease.org/rss/?t&r=1080', api_keys, dirname+'/downloads');
await ap.full(); //Or use ap.downloadOnly() to only download and no upload.
}
auto();
- Run the script with
node index.js
or schedule to run the script each day around the time when new episodes are released (6am JST is Optimal) with cron or your preffered task scheduler.
Usage (Docker)
Check out /examples/docker for details.
Work to create the Docker Image is already done (see examples/docker/Dockerfile). These instructions help you to set up a directory and docker-compose.yml file to pull the image from the internet and run.
Create a new directory. Create a "data" folder within this new directory.
Within the data folder, create a valid shows.json file eg: (examples/docker/data/shows.json)
{
"list": [
{
"name": "Horimiya",
"nextEp": 4,
"day": 0
}
]
}
- Back in the new directory, create a docker-compose.yml file eg: (examples/docker/docker-compose.yml)
version: "3"
services:
anime:
image: nlanson/rawdl:fd
# There are other images for different run modes.
# nlanson/rawdl:fd for Full download and upload as well as file deletion upon completion.
# nlanson/rawdl:f for Full download and upload and keeping files.
# nlanson/rawdl:do for Download only and no upload.
environment:
#If you are using the Download Only Image (nlanson/rawdl:do), no environment variables are necessary.
API_USERNAME: '<your streamtape api username>'
API_PASSWORD: '<your streamtape api password>'
API_FOLDER: '<your streamtape folder id>'
volumes:
- "./data:/data"
container_name: rawdl
tty: true
stdin_open: true
Use command
docker-compose up -d -it
from within the new directory and the rawdl container should start. Access the container usingdocker attach rawdl
. Now the container should read the shows.json file from the mounted ./data/shows.json and download then upload new episodes it has found.Schedule the container to run daily (6am JST is best) with crontab.
Upcoming
- Utility feature to aide creating shows.json
- Utility to aide setup of the script environment.