Skip to content

An extensible Ruby framework for managing external processes.

License

Notifications You must be signed in to change notification settings

npickens/potluck

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

69 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Potluck

Potluck is an extensible Ruby framework for configuring, controlling, and interacting with external processes. It leverages launchctl for starting and stopping processes when the command is available (e.g. when developing locally on macOS) while gracefully taking either a more passive or manual role with external processes in other environments (e.g. production).

The core Potluck gem provides a simple interface which is used by service-specific extensions to the gem. Currently there are two official extensions:

  • Potluck::Nginx - Generates Nginx configuration files and (optionally) controls the Nginx process with launchctl or manual commands. Allows for multiple Ruby apps as well as other external processes to all seamlessly use Nginx simultaneously.
  • Potluck::Postgres - Provides control of the Postgres process and basic common functionality for connecting to and setting up a database. Uses the Sequel and pg gems.

Installation

Add this line to your Gemfile:

gem('potluck')

Or install manually on the command line:

gem install potluck

Usage

The core Potluck gem is not meant to be used directly. Rather its Service class defines a common interface for external processes which can be inherited by service-specific child classes. See Potluck::Nginx and Potluck::Postgres for examples.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/npickens/potluck.

License

The gem is available as open source under the terms of the MIT License.

About

An extensible Ruby framework for managing external processes.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages