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

distsync

v1.1.1

Published

a local-remote directory synchronizer

Downloads

107

Readme

distsync

A utility for uploading a directory to the server. It is typically used to synchronize the remote public_html directory with local dist directory created by some build tools such as Vite.

Setup

npm install distsync

Usage

  1. Write a configuration file distsync.config.js.
  2. Run distsync command.

Configuration

You can write the configuration of distsync in one of the following files (see cosmiconfig for details):

  • .distsyncrc, .distsyncrc.js, or .distsyncrc.json
  • distsync.config.js

The following is an example of a configuration file:

export default {
  // the URL of the server and directory where the files are uploaded.
  remote: "ftp://example.com/users/foo/public_html/",

  // the remote filename for the distsync's index file.
  indexName: ".htdistsync",

  // the source directories
  sources: [
    {
      // the relative path of a directory from this configuration file.
      directory: "dist",

      // rules for file selection and postprocessing.
      rules: {
        // before uploading, HTML files except for index.html are compressed
        // by gzip and renamed to index.html.gz.
        files: "**/*.html",
        exclude: "**/index.html",
        transform: "gzip",
        remoteName: "*.gz"
      }
    }
  ]

A user configuration must be an object of the following UserConfig type:

interface UserConfig {
  remote?: URL | string;
  passwordCommand?: string;
  indexName?: string;
  sources?: Array<string | UserSource> | string | UserSource;
}

interface UserSource {
  directory?: string;
  rules?: UserRule[] | UserRule;
}

type Transform =
  (data: Data, name: string) => Promise<Buffer | string> | Buffer | string;

type RemoteName =
  (name: string) => Promise<string | undefined> | string | undefined;

interface UserRule {
  files?: Array<string | RegExp> | string | RegExp;
  exclude?:  Array<string | RegExp> | string | RegExp;
  transform?: Transform | "gzip" | "brotli";
  remoteName?: RemoteName | string;
  ignore?: boolean;
}

remote

| type | default | |------|---------| | string | distsync directory of the current directory |

The absolute URL of the remote directory. The following protocol are allowed: file: (local copy for testing), http: and https: (WebDAV), sftp:, and ftp:.

passwordCommand

| type | default | |------|---------| | string | (print Password: prompt) |

The command that obtains secret password.

indexName

| type | default | |------|---------| | string | ".htdistsync" |

The filename of the index file created by distsync in the remote directory.

The index file is used to determine the difference between the contents of local and remote directories.

sources

| type | default | |------|---------| | Array<string \| UserSource> \| string \| UserSource | "dist" |

The directory containing files to be uploaded.

Each directory must be specified by its name (string) or as an object (UserSource). The UserSource object consists of the directory and rules property, described below. It is allowed to specify multiple directories by an array.

directory

| type | default | |------|---------| | string | "dist" |

The name of source directory, which may be a relative path from the configuration file.

rules

| type | default | |------|---------| | UserRule[] \| UserRule | [] |

If an object is given to the sources property, it may optionally have the rules property for file selection and transformation before uploading. Each rule may have the files, exclude, transform, remoteName, and/or ignore properties, all of which are described below.

If multiple rules are specified by an array, rules are sequentially applied to each file.

files

| type | default | |------|---------| | Array<string \| RegExp> \| string \| RegExp | "**/*" |

File name patterns that matches with files that this rule is applied. If it is omitted, the rule is applied to all files.

exclude

| type | default | |------|---------| | Array<string \| RegExp> \| string \| RegExp | [] |

The rule is not applied to files matched with this pattern.

transform

| type | default | |------|---------| | function \| "gzip" \| "brotli" | undefined |

The contents of the file is manipulated by the given function before uploading.

The type of the transform function is

(data: Data, name: string) => Promise<Buffer | string> | Buffer | string

where

interface Data {
    readonly string: string;
    readonly buffer: Buffer;
}

The function must take the file contents (data) and file name (name) and returns new contents as a Buffer or string.

If "gzip" or "brotli" is specified, the file is compressed with the specified compressor, which is Node.js's built-in.

Multiple transformation can be chained by multiple rules. For example, you can optimize SVG files and then compress it by the sequential two rules.

{
  directory: "dist",
  rules: [
    {
      files: "**/*.svg",
      transform: (data, path) =>
        svgo.optimize(buf.string, { path, multipass: true }).data
    },
    {
      files: ["**/*.{svg,html}"],
      transform: "gzip",
      remoteName: "*.gz"
    }
  ]
}

remoteName

| type | default | |------|---------| | function \| string | undefined |

The remoteName function manipulates file names before uploading. The type of the function is the following:

(name: string) => Promise<string | null | Undefined> | string | null | undefined

The function takes the file name in the local directory and returns a new name in the remote directory. It may return null or undefined to prevent distsync from uploading this file.

If remoteName is a string, the string is used for the new file name with replacing * occurring in the string with the original file name.

Multiple renaming can be chained by multiple rules.

ignore

| type | default | |------|---------| | boolean | false |

Files matched with this rule are not uploaded.

This is a shorthand for remoteName: () => undefined.

License

MIT