1.0.4 • Published 4 years ago

@ignitionwolf/ignite v1.0.4

Weekly downloads
-
License
MIT
Repository
github
Last release
4 years ago

ignite

oclif Version

Ignite is a high-level utility tool to fire up local environments easily based on a configuration file. This is as simple as setting up your Ignitefile (ignite init and modify it accordingly), then ignite up!.

This works thanks to Vagrant and VirtualBox or VMWare. This means you will need to install these dependencies first before trying to run Ignite.

This is still in early stages, it is fully functional but more features like packages and site types are still being worked on. In the meanwhile, you're free to submit pull requests with more Ansible packages support and site types default configuration.

Install

npm install -g @ignitionwolf/ignite

Usage

$ ignite init
initializing Ignitefile... initialized

$ ignite up
booting the machine... booted

$ ignite ssh
...

Creating your Ignitefile

It's as simple as running ignite init, however, you can see a detailed template below:

## Local development machine information
meta:
  name: 'Default Ignite Box'
  box: 'centos/7'
  ip: 192.168.10.33

## Sites that will be automatically configured by 
sites:
  - hostname: custom.local ## You'll have to configure this in your hosts file
    path: /path/to/project/files ## This will be ported to the development machine
    public_folder: './public' ## Relative path in the project to the public directory

  - hostname: laravel.local
    git: https://github.com/user/laravel-local.git
    type: laravel

## Must be any supported dependency by Ignite.
dependencies:
  - name: php
    version: 7.4
    extensions:
      - gd

  - name: composer
  - name: apache
  - name: nodejs

## Runs before the dependencies are installed.
pre_tasks:
  - path: '/var/www/git-example'
    cmd: 'composer install'

## Runs after the dependencies are installed.
tasks:
  - path: '/var/www/git-example'
    cmd: 'composer install'

## Utilities/programs to install.
utilities:
  - htop

Commands

ignite destroy

Turn off an environment machine

USAGE
  $ ignite destroy

OPTIONS
  -f, --force      proceed forcefully
  -p, --path=path  target path (optional)
  -v, --verbose    verbose output

DESCRIPTION
  This will put the environment machine offline.

See code: src/commands/destroy.ts

ignite down

Turn off an environment's machine

USAGE
  $ ignite down

OPTIONS
  -p, --path=path  Target path (optional)
  -v, --verbose    verbose output

DESCRIPTION
  This will put the environment's machine offline.

See code: src/commands/down.ts

ignite help [COMMAND]

display help for ignite

USAGE
  $ ignite help [COMMAND]

ARGUMENTS
  COMMAND  command to show help for

OPTIONS
  --all  see all commands in CLI

See code: @oclif/plugin-help

ignite init [NAME]

Initialize a Ignitefile configuration file

USAGE
  $ ignite init [NAME]

OPTIONS
  -p, --path=path  Target path (optional)

DESCRIPTION
  Modify this file to instruct Ignite on how to setup your desired environment.

See code: src/commands/init.ts

ignite ssh

SSH in the provisioned machine

USAGE
  $ ignite ssh

OPTIONS
  -p, --path=path  Target path (optional)
  -v, --verbose    verbose output

DESCRIPTION
  This will not load keys

See code: src/commands/ssh.ts

ignite ssh-config

Get the SSH config to access the machine

USAGE
  $ ignite ssh-config

OPTIONS
  -p, --path=path  Target path (optional)
  -v, --verbose    verbose output

DESCRIPTION
  You can use this to configure your IDE remote connection.

See code: src/commands/ssh-config.ts

ignite status

Get the status of the environment machine.

USAGE
  $ ignite status

OPTIONS
  -p, --path=path  Target path (optional)
  -v, --verbose    verbose output

DESCRIPTION
  This will tell you if the machine is running, offline, or suspended.

See code: src/commands/status.ts

ignite suspend

Turn off an environment machine

USAGE
  $ ignite suspend

OPTIONS
  -p, --path=path  Target path (optional)
  -v, --verbose    verbose output

DESCRIPTION
  This will put the environment machine offline.

See code: src/commands/suspend.ts

ignite up

Ignite an environment based on Ignitefile

USAGE
  $ ignite up

OPTIONS
  -p, --path=path  Target path (optional)
  -v, --verbose    verbose output

DESCRIPTION
  This might take some time while the configuration is processed and the machine is ignited.

See code: src/commands/up.ts

Dependencies

A "dependency" is a configuration class that links the required dependency to an Ansible role. You can't directly install an Ansible role, it has to be supported by Ignite first. If you don't see a package listed here that you need, please write an issue or a pull request with the respective Ansible role. It's important to note that it must work in different linux distributions.

Supported Packages

  • Apache Web Server apache
  • PHP php
  • Composer composer
  • NodeJS nodejs
  • Redis redis
dependencies:
  - name: php
    version: 7.4
    extensions:
      - gd

  - name: composer
  - name: apache
  - name: nodejs

Sites

You can load a site project files from a local path in your machine or from a git repository.

sites:
  - hostname: example.local
    public_folder: ./public
    git: https://github.com/user/repo.git

  - hostname: laravel.local
    type: laravel
    path: /path/to/my/site/files

You will need to add these hostnames to your hosts file with the machine IP found at the metadata section of the Ignitefile.

Site Types

A "site type" is a set of necessary configuration/tasks that needs to be executed in order to prepare for a specific website structure. For example, this sets up the virtual hosts in the correct directory and assigns directory permissions.

Supported Site Types

  • Laravel

Tasks

You can run shell commands to do any extra provisioning work you may need in order to get your site working.

## Runs before installing dependencies
pre_tasks:
  path: /where/to/run/the/cmd
  inline: ls -l

## Runs after installing dependencies
tasks:
  path: /where/to/run/the/cmd
  inline: ls -l

Utilities

You can install any extra software by adding it to this list.

utilities:
  - htop
  - curl

Built With

Authors

License

Acknowledgments

  • Ansible Community
  • Vagrant Community
  • Jeff Geerling - awesome Ansible roles