Trivially start a DigitalOcean droplet and start an Urbit planet.
WARNING: This script could result in the need for a breach if misused or if you hit an unknown bug. Use carefully.
This project is intended to simplify initial boot of an Urbit planet. After initial boot the user will need to manage the planet manually as normal. The playbook avoids restarting a running planet, so running multiple times should not cause an issue.
- Urbit planet name
- Urbit network key for the planet
- DigitalOcean token
The droplet that is created uses a hard coded configuration that can be found and modified here. There is an issue created to make this configurable with defaults. In the mean time, modification of this file before running the script will allow you to specify your exact preferences. Note that the syntax for droplet sizing is specific. You can find the DigitalOcean table specifying limits and size types here.
./droplet_create.sh -n PLANET_NAME -t DIGITAL_OCEAN_TOKEN -k URBIT_NETWORK_KEY
takes the planet name, network key, and DigitalOcean token and creates a properly sized and named Droplet with a properly configuredauthorized_keys
entry for Ansible to use. It then adds the planet to inventory with the correct variables. If you want to SSH into the host, you can use the keys that are generated and placed in thekeys
directory. This script currently starts a default droplet and does not harden the server with additional security settings.ansible-playbook -i inventory/hosts setup.yml
uses the settings ininventory/hosts
to boot each planet if it has not yet been booted. If you get an error likeFailed to connect to the host via ssh
wait a moment and run the playbook again. The Droplet may just not be fully initiailized.
WARNING: The droplet_create.sh
script adds server details to the inventory/hosts
file. This data should not be pushed into a public repository. Ensure that you remove this information before creating a PR or pushing to a public fork.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.