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 🙏

© 2026 – Pkg Stats / Ryan Hefner

syno

v3.0.2

Published

Node.js wrapper and CLI for Synology DSM REST API 6.x and 7.x

Readme

Syno

Node.js wrapper and CLI for Synology DSM REST API 6.x and 7.x.

npm version

See Synology Development Tool.

Installation

npm install syno

For the CLI:

npm install -g syno

Requires Node.js >= 24.0.0

Syno API

  • DSM API (SYNO.DSM, SYNO.Core)
  • File Station API (SYNO.FileStation)
  • Download Station API (SYNO.DownloadStation)
  • Audio Station API (SYNO.AudioStation)
  • Video Station API (SYNO.VideoStation)
  • Video Station DTV API (SYNO.DTV)
  • Surveillance Station API (SYNO.SurveillanceStation)
  • Synology Photos API (SYNO.Foto, SYNO.FotoTeam) - DSM 7.x only

For detailed parameters and response data, refer to the Synology Developer Tool page.

JavaScript / TypeScript

import { Syno } from 'syno';

const syno = new Syno({
    // Requests protocol: 'http' or 'https' (default: 'http')
    protocol: 'https',
    // DSM host: IP or domain name (default: 'localhost')
    host: 'localhost',
    // DSM port (default: 5000)
    port: 5001,
    // DSM User account (required)
    account: 'my_username',
    // DSM User password (required)
    passwd: 'my_password',
    // DSM API version (default: '7.2')
    apiVersion: '7.2',
});

All methods return Promises:

const info = await syno.fs.getInfo();

Or call a method dynamically:

const info = await syno.fs.call('getInfo', { folder_path: '/path' });

Examples

// DSM API - Provide DSM information
const dsmInfo = await syno.dsm.getInfo();

// File Station API - Provide File Station information
const fsInfo = await syno.fs.getInfo();

// File Station API - Enumerate files in a given folder
const files = await syno.fs.list({ folder_path: '/path/to/folder' });

// Download Station API - List download tasks
const tasks = await syno.dl.listTasks({ limit: 5, offset: 10 });

// Download Station API - Create a download task
await syno.dl.createTask({ uri: 'https://link' });

// Audio Station API - Search a song
const songs = await syno.as.searchSong({ title: 'my_title_song' });

// Video Station API - List movies
const movies = await syno.vs.listMovies({ limit: 5 });

// Video Station DTV API - List channels
const channels = await syno.dtv.listChannels({ limit: 5 });

// Surveillance Station API - Get camera information
const camera = await syno.ss.getInfoCamera({ cameraIds: 4 });

// Synology Photos API (DSM 7.x) - List albums
const albums = await syno.photo.listAlbums();

Configuration Options

| Option | Type | Default | Description | |---|---|---|---| | account | string | - | DSM user account (required) | | passwd | string | - | DSM user password (required) | | protocol | string | 'http' | 'http' or 'https' | | host | string | 'localhost' | DSM hostname or IP | | port | number | 5000 | DSM port | | apiVersion | string | '7.2' | DSM API version | | debug | boolean | false | Enable debug logging | | ignoreCertificateErrors | boolean | false | Ignore TLS certificate errors | | otpCode | string | - | Two-factor auth OTP code | | sid | string | - | Reuse an existing session ID | | followRedirects | boolean | true | Follow HTTP redirects (QuickConnect) |

Station Aliases

| Short | Long | Class | |---|---|---| | syno.dsm | syno.diskStationManager | DSM | | syno.fs | syno.fileStation | FileStation | | syno.dl | syno.downloadStation | DownloadStation | | syno.as | syno.audioStation | AudioStation | | syno.vs | syno.videoStation | VideoStation | | syno.dtv | syno.videoStationDTV | VideoStationDTV | | syno.ss | syno.surveillanceStation | SurveillanceStation | | syno.photo | syno.synologyPhotos | SynologyPhotos |

CLI

$ syno --help
Usage: syno [options] [command]

Synology Rest API Command Line

Options:
  -V, --version                              output the version number
  -c, --config <path>                        DSM Configuration file. Default to ~/.syno/config.yaml
  -u, --url <url>                            DSM URL. Default to https://admin:password@localhost:5001
  -d, --debug                                Enabling Debugging Output
  -a, --api <version>                        DSM API Version. Default to 7.2
  -i, --ignore-certificate-errors            Ignore certificate errors
  -h, --help                                 display help for command

Commands:
  diskstationmanager|dsm [options] <method>  DSM API
  filestation|fs [options] <method>          DSM File Station API
  downloadstation|dl [options] <method>      DSM Download Station API
  audiostation|as [options] <method>         DSM Audio Station API
  videostation|vs [options] <method>         DSM Video Station API
  videostationdtv|dtv [options] <method>     DSM Video Station DTV API
  surveillancestation|ss [options] <method>  DSM Surveillance Station API
  synologyphotos|photo [options] <method>    DSM Synology Photos API

CLI Examples

# DSM API - Provide DSM information
$ syno dsm getInfo --pretty

# File Station API - Enumerate files in a given folder
$ syno fs listFiles --payload '{"folder_path":"/path/to/folder"}' --pretty

# Download Station API - Create a download task
$ syno dl createTask --payload '{"uri":"https://link"}'

# Audio Station API - Search a song
$ syno as searchSong --payload '{"title":"my_title_song"}' --pretty

# Video Station API - List movies
$ syno vs listMovies --payload '{"limit":5}' --pretty

# Video Station DTV API - List channels
$ syno dtv listChannels --payload '{"limit":5}' --pretty

# Surveillance Station API - Get camera information
$ syno ss getInfoCamera --payload '{"cameraIds":4}' --pretty

CLI Authentication

Via environment variables

export SYNO_ACCOUNT=user
export SYNO_PASSWORD=password
export SYNO_PROTOCOL=https
export SYNO_HOST=localhost
export SYNO_PORT=5001

Via URL

$ syno fs getInfo --url https://user:password@localhost:5001 --pretty

Via configuration file

# ~/.syno/config.yaml
url:
  protocol: https
  host: localhost
  port: 5001
  account: admin
  passwd: password
$ syno fs getInfo --pretty

More usage examples in the wiki.

Migrating from 2.x to 3.x

Breaking changes

  • Async/await only — All methods now return Promises. Callbacks are no longer supported.
    // Before (2.x)
    syno.fs.getInfo(function(err, data) { ... });
    // After (3.x)
    const data = await syno.fs.getInfo();
  • Node.js 24+ required — Uses native fetch, no polyfills needed.
  • Browser support removed — Node.js only. Browser bundles are no longer shipped.
  • Default API version changed from 6.0.2 to 7.2.
  • DSM 5.x support dropped — Only 6.x and 7.x definitions are included.
  • ESM + CJS dual outputimport { Syno } from 'syno' or const { Syno } = require('syno').
  • TypeScript types included — No separate @types package needed.

Tips & Tricks

If you encounter certificate errors with https:

[ERROR] : Error: UNABLE_TO_VERIFY_LEAF_SIGNATURE

Use the --ignore-certificate-errors flag:

$ syno fs getInfo --ignore-certificate-errors

Or set the environment variable:

export SYNO_IGNORE_CERTIFICATE_ERRORS=1

Or in code:

const syno = new Syno({
    ignoreCertificateErrors: true,
    // ...
});

History

View the changelog

Authors

License

MIT - See LICENSE-MIT