- Make sure you can successfully run docker commands without sudo. See Ubuntu example.
OSX users: You may need to start your Docker daemon with the command:
docker-machine start default
eval $(docker-machine env default)
before proceeding.
See also the wiki for platform-specific instructions.
Use the following command to install bowline into your new or existing Drupal project directory.
wget 'https://raw.githubusercontent.com/davenuman/bowline/master/lib/bowline/install.sh' -O bowline-install.sh ; cat bowline-install.sh ; read -n1 -p "Run above script? (y/n)" ; if [ "$REPLY" = "y" ]; then bash bowline-install.sh; fi
Activate bowline, adding the bowline environment to your bash session (The "dot space" is intentional, not a typo):
. bin/activate
This should add your project name to your bash prompt to indicate that your session has extra features. For example, ~/myproject (myproject) $.
Enter bowline
to see a list commands available and the status of the containers. Note that the commands listed (such as drush) override any commands that were previously in your $PATH.
You may have noticed when running the bowline
command that there is a section called "Proxy". As it suggests, run the following command to activate the proxy:
invoke_proxy
This will create and start an nginx container linked to a dnsmasq container. After they start it will add the web IP address and the project name to the dns container. The nginx proxy then uses that dns for finding your site and servers it as {projectname}.localtest.me (for example https://myproject.localtest.me/). Once the proxy is active, bowline is aware of it when using the bowine
or drush
commands:
bowline
drush st
Important: the nginx proxy will not start if you have something else using port 80. You must either stop your other service (recommended) or edit the port in lib/proxy/fig.yml
file to something other than 80.
- Review sandbox.md which is indented to become your instructions for your development team. It will need to be modified to the specifics of your project.
- Replace the content of this readme.md file with appropriate description of your project.
The intention for typical usage of Bowline is to set up this repository as a secondary git remote. If you followed these instructions, the remote is called bowline. (You can add whatever is appropriate for your project as the origin remote.)
If you would like to pull in the latest Bowline code you basically just need to update the bin and lib directories.This can be done with the following command:
git checkout bowline/master -- bin lib
Then review the change and commit the update and push to your project.
Bowline aims to be a general purpose tool while also allowing for any project specific needs. The hoist command helps to allow for many features yet keep simplicity for less involved projects. The word "hoist" is playing on the sailing term, suggesting that you would use the appropriate rigging depending on the direction you are heading.
After activating, running the hoist
command will output something similar to this:
Usage: hoist [rigging]
Available riggings:
behat devtools drupal-core-dev
So to "hoist" the behat rigging for your project you would do this:
hoist behat
Thus, you can easily install the pieces you need for your project. Each hoisting is logged in logs/rigging
Riggings are simply a directory with a rigging_name.hoist bash script. A good example is the behat rigging. The behat.hoist script runs a composer command and copies a file to the bin directory, which may be typical processes of other possible riggings.
Pull requests welcome in typical GitHub fashion. If you would like to add a new feature to the project, consider using the hoist method described above.