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

@btheo/dpl

v1.2.0

Published

Simple deployment tool for Docker projects

Downloads

200

Readme

DPL (Docker Project Deployer)

A streamlined CLI tool for deploying Docker projects over SSH with multi-target support and secure authentication handling.

TypeScript

✨ Key Features

  • 🔐 Flexible authentication (Password/SSH Key)
  • 🔑 Secure Git credential management
  • 📦 Multiple deployment target support
  • 🐳 Seamless Docker Compose integration
  • 💻 Interactive configuration wizard
  • 🚀 One-command deployment
  • 🛡️ Secure credential handling

📦 Installation

npm install -g @btheo/dpl

🚀 Quick Start

  1. Configure a deployment target:
# Password authentication
dpl configure myserver --password

# SSH key authentication (defaults to ~/.ssh/id_rsa)
dpl configure myserver --ssh-key
  1. Deploy your project:
# Standard deployment
dpl deploy myserver

# Deploy without Git authentication
dpl deploy myserver --skip-git-auth

📖 Command Reference

Configure New Target

dpl configure [alias] [options]

Options:

  • --password - Use password authentication
  • --ssh-key - Use SSH key authentication
  • --git-auth - Include Git authentication setup

The wizard will guide you through configuring:

  • Remote host details
  • Authentication method
  • Project location
  • Git credentials (optional)

Deploy Project

dpl deploy <alias> [options]

Options:

  • --skip-git-auth - Bypass Git authentication

Deployment Process:

  1. SSH connection establishment
  2. Git authentication setup (if configured)
  3. Code pull from repository
  4. Container management:
    • Stop running containers
    • Clean Docker resources
    • Start new containers
  5. Status verification
  6. Cleanup of temporary files

Manage Configurations

# List all targets
dpl list

# Remove a target
dpl remove <alias>

# Duplicate a configuration
dpl duplicate <alias> <newAlias> <newFolderPath>

🔒 Security Features

  • Encrypted storage of sensitive data
  • SSH key path references only (no key storage)
  • Automatic cleanup of authentication artifacts
  • Secure Git credential handling
  • Isolated configuration per user

💾 Configuration Storage

Configurations are securely stored in:

  • macOS: ~/Library/Preferences/dpl-nodejs
  • Linux: ~/.config/dpl-nodejs
  • Windows: %APPDATA%\dpl-nodejs

🛠️ Development Setup

Prerequisites

  • Node.js ≥ 14
  • npm ≥ 6

Local Development

# Clone repository
git clone https://github.com/yourusername/dpl.git
cd dpl

# Setup project
npm install
npm run build

# Link for local testing
npm link

# Run tests
npm test
npm run test:watch
npm run test:coverage

🤝 Contributing

  1. Fork the repository
  2. Create your feature branch
    git checkout -b feature/amazing-feature
  3. Commit your changes
    git commit -m 'Add amazing feature'
  4. Push to the branch
    git push origin feature/amazing-feature
  5. Open a Pull Request

📄 License

Licensed under the MIT License - see the LICENSE file for details.