# Smart CDN A static server with some smart features.
This was a personal project that I found useful and I wanted to share it. It basically is a static content server with some extra features that I found interesting to have.
- Static Content Server: Serve files from a folder.
- CLI: Command line utility to start the server and publish packages to it.
- Semver routes: Use semver in the version segment of the URL to get the latest matching version.
- SourceMap: Add a source map header and reference at the end of each file to serve source map files to the browser.
- Uplink server: Fallback server to request files not found in the local one.
- ImportMap: Include redirections for paths.
- Cache: Add long term cache
- Config file path: Point to a config file out of the directory where the server has been started.
- Watch mode: Auto publish a package every time a file is updated in the folder where the bundled code is dropped.
- Secure Mode: The server rejects to override a version already published.
Coming soon:
- Web UI: A web interface to search and inspect published packages and server configuration.
- Popular CDNs as uplinks: Configure the server to use CDNs such as Skypack as uplink using a single option ( --uplink-skypack ).
Install it globally using yarn or npm
npm install -g scdn
The server can be configured using ENV variables and/or using a config file. ENV variables take precedence over config file values.
ENV variables you can set are: port
, packagesFolder
and uplink
.
The config file should be placed in the folder where the server is being started with scdn.config.js
name. You can set dynamic configuration in this file for different running environments.
const config = {
host: "my.cdn.com",
port: 3000,
packagesFolder: "~/.cdnPackages",
redirections: {
"test@latest": "/test/2.0.0/entryPoint.js",
},
};
if (process.env.NODE_ENV === "production") {
config.port = 4000;
config.redirections["test@latest"] = "/test/1.0.0/entryPoint.js";
}
export default config;
The package includes the scdn
CLI command.
Starts the server with the default configuration. This command has these options:
- -n, --host: The host name to be used in urls pointing to the server. [default: localhost]
- -p, --port: The port the server will be listening to. [default: 3000]
- -f, --packagesFolder: The path to the folder where the packages are/will be stored. [default: <USER_HOME>/.scdn]
- -u, --uplink: The first URL section of the server to be used as fallback. For example: https://uplink.cdn.com . [default: none]
- -s, --secure: Run the server in secure mode. In secure mode, publishing the same version of a package is forbiden. [default: false]
- -h: Print this help.
Examples:
> scdn start
> scdn start -s -n my.cdn.com -p 3001 -f /packages -u https://uplink.cdn.com
> scdn start --secure --host my.cdn.com --port 3001 --packagesFolder /packages --uplink https://uplink.cdn.com
Publish a package to the server. The dist folder, package.json and README.md files are pushed to the server and stored. If you are not in the root of the package, or the dist folder is different, or the server is in a different machine, you can configure the options.
- -p, --port: Port number where the server is listening to. [default: 3000]
- -n, --host: host name or ip where the server is hosted. [default: localhost]
- -f, --folder: path to the folder where the the content to publish is placed. [default: ./dist]
- -r, --readme: Path to the README.md to include [default: ./REAME.md]
- -i, --package: Path to re package.json to include. [default: ./package.json]
- -w, --watch: Watch the folder to publish the content when it changes.
- -h: Print this help.
Examples:
> scdn publish
> scdn -n 192.168.0.1 -p 3001 -f /packages/todo/bundle -r /packages/todo/README.md -i /pacakges/todo/package.json
> scdn publish -w
Alias:
info
Retrieve relevant information from any package published in the CDN
Example:
> scdn view my-package
The server supports semmantic versioning in the URL, so routes like these can be used to get latest version matching it.
// from 1.0.0 up to but not including the next minor version (1.1.0)
import "http://localhost:3000/todo/^1.0/index.js";
// from 1.0.0 up to but not including the next major version (2.0.0)
import "http://localhost:3000/todo/~1/index.js";