108 lines
		
	
	
	
		
			4.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			108 lines
		
	
	
	
		
			4.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | ||
| title: Announcing the Drupal VM Generator
 | ||
| date: 2016-02-15
 | ||
| excerpt:
 | ||
|   For the past few weeks, I’ve been working on a personal side project based on
 | ||
|   Drupal VM - the Drupal VM Generator.
 | ||
| tags:
 | ||
|   - drupal
 | ||
|   - drupal-planet
 | ||
|   - drupal-vm
 | ||
|   - drupal-vm-generator
 | ||
|   - symfony
 | ||
| ---
 | ||
| 
 | ||
| For the past few weeks, I’ve been working on a personal side project based on
 | ||
| Drupal VM. It’s called the [Drupal VM Generator][1], and over the weekend I’ve
 | ||
| added the final features and fixed the remaining issues, and tagged the 1.0.0
 | ||
| release.
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| ## What is Drupal VM?
 | ||
| 
 | ||
| [Drupal VM][2] is a project created and maintained by [Jeff Geerling][3]. It’s a
 | ||
| [Vagrant][4] virtual machine for Drupal development that is provisioned using
 | ||
| [Ansible][5].
 | ||
| 
 | ||
| What is different to a regular Vagrant VM is that uses a file called
 | ||
| `config.yml` to configure the machine. Settings such as `vagrant_hostname`,
 | ||
| `drupalvm_webserver` and `drupal_core_path` are stored as YAML and passed into
 | ||
| the `Vagrantfile` and the `playbook.yml` file which is used when the Ansible
 | ||
| provisioner runs.
 | ||
| 
 | ||
| In addition to some essential Ansible roles for installing and configuring
 | ||
| packages such as Git, MySQL, PHP and Drush, there are also some roles that are
 | ||
| conditional and only installed based on the value of other settings. These
 | ||
| include Apache, Nginx, Solr, Varnish and Drupal Console.
 | ||
| 
 | ||
| ## What does the Drupal VM Generator do?
 | ||
| 
 | ||
| > The Drupal VM Generator is a Symfony application that allows you to quickly
 | ||
| > create configuration files that are minimal and use-case specific.
 | ||
| 
 | ||
| Drupal VM comes with an [example.config.yml file][6] that shows all of the
 | ||
| default variables and their values. When I first started using it, I’d make a
 | ||
| copy of `example.config.yml`, rename it to `config.yml` and edit it as needed,
 | ||
| but a lot of the examples aren’t needed for every use case. If you’re using
 | ||
| Nginx as your webserver, then you don’t need the Apache virtual hosts. If you
 | ||
| are not using Solr on this project, then you don’t need the Solr variables.
 | ||
| 
 | ||
| For a few months, I’ve kept and used boilerplace versions of `config.yml` - one
 | ||
| for Apache and one for Nginx. These are minimal, so have most of the comments
 | ||
| removed and only the variables that I regularly need, but these can still be
 | ||
| quite time consuming to edit each time, and if there are additions or changes
 | ||
| upstream, then I have two versions to maintain.
 | ||
| 
 | ||
| The Drupal VM Generator is a Symfony application that allows you to quickly
 | ||
| create configuration files that are minimal and use-case specific. It uses the
 | ||
| [Console component][7] to collect input from the user, [Twig][8] to generate the
 | ||
| file, the [Filesystem component][9] to write it.
 | ||
| 
 | ||
| Based on the options passed to it and/or answers that you provide, it generates
 | ||
| a custom, minimal `config.yml` file for your project.
 | ||
| 
 | ||
| Here’s an example of it in action:
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| You can also define options when calling the command and skip any or all
 | ||
| questions. Running the following would bypass all of the questions and create a
 | ||
| new file with no interaction or additional steps.
 | ||
| 
 | ||
| {{ gist('24e569577ca4b72f049d', 'with-options.sh') }}
 | ||
| 
 | ||
| ## Where do I get it?
 | ||
| 
 | ||
| The project is hosted on [GitHub][1], and there are installation instructions
 | ||
| within the [README][10].
 | ||
| 
 | ||
| <div class="github-card" data-github="opdavies/drupal-vm-generator" data-width="400" data-height="" data-theme="default"></div>
 | ||
| 
 | ||
| The recommended method is via downloading the phar file (the same as Composer
 | ||
| and Drupal Console). You can also clone the GitHub repository and run the
 | ||
| command from there. I’m also wanting to upload it to Packagist so that it can be
 | ||
| included if you manage your projects with Composer.
 | ||
| 
 | ||
| Please log any bugs or feature requests in the [GitHub issue tracker][11], and
 | ||
| I’m more than happy to receive pull requests.
 | ||
| 
 | ||
| If you’re interested in contributing, please feel free to fork the repository
 | ||
| and start doing so, or contact me with any questions.
 | ||
| 
 | ||
| **Update 17/02/16:** The autoloading issue is now fixed if you require the
 | ||
| package via Composer, and this has been tagged as the [1.0.1 release][12]
 | ||
| 
 | ||
| [1]: https://github.com/opdavies/drupal-vm-generator
 | ||
| [2]: http://www.drupalvm.com
 | ||
| [3]: http://www.jeffgeerling.com
 | ||
| [4]: http://www.vagrantup.com
 | ||
| [5]: https://www.ansible.com
 | ||
| [6]: https://github.com/geerlingguy/drupal-vm/blob/master/example.config.yml
 | ||
| [7]: http://symfony.com/doc/current/components/console/introduction.html
 | ||
| [8]: http://twig.sensiolabs.org
 | ||
| [9]: http://symfony.com/doc/current/components/filesystem/introduction.html
 | ||
| [10]:
 | ||
|   https://github.com/opdavies/drupal-vm-generator/blob/master/README.md#installation
 | ||
| [11]: https://github.com/opdavies/drupal-vm-generator/issues
 | ||
| [12]: https://github.com/opdavies/drupal-vm-generator/releases/tag/1.0.1
 |