GithubHelp home page GithubHelp logo

isabella232 / terraform-provisioner-online-rescue Goto Github PK

View Code? Open in Web Editor NEW

This project forked from src-d/terraform-provisioner-online-rescue

0.0 0.0 0.0 6.86 MB

Terraform provisioner for Online.net rescue mode

License: Mozilla Public License 2.0

Makefile 21.39% Go 56.44% Shell 22.17%

terraform-provisioner-online-rescue's Introduction

Terraform Provisioner for Online.net server rescue mode

Requirements

  • Terraform 0.10.x
  • Go 1.8 (to build the provider plugin)

About The Provisioner

This provisioner is built to enable the Online.net rescue mode on a server and then execute actions to it via remote-exec when it is being created.
This can be used to for example format the disks or install a specific OS.

Building The Provisioner

Clone repository to: $GOPATH/src/github.com/src-d/terraform-provisioner-online-rescue

$ mkdir -p $GOPATH/src/github.com/scr-d; cd $GOPATH/src/github.com/src-d
$ git clone [email protected]:src-d/terraform-provisioner-online-rescue

Enter the provider directory and build the provider

$ cd $GOPATH/src/github.com/src-d/terraform-provisioner-online-rescue
$ make build

Using the provisioner

resource "online_server" "dedibox" {
    provisioner "online-rescue" {
        "enabled" = true
        "server" = "${online_server.dedibox.id}"
        "image" = "ubuntu-18.04_amd64"
        "credentials_dir" = "/tmp/${online_server.dedibox.id}"
    }

    // the following is a hack as provisioners can not output data
    connection {
        host = "${file("/tmp/${online_server.dedibox.id}/ip")}"
        type     = "ssh"
        user     = "${file("/tmp/${online_server.dedibox.id}/username")}"
        password = "${file("/tmp/${online_server.dedibox.id}/password")}"
    }

    provisioner "remote-exec" {
        inline = [
        "mkfs.ext4 /dev/sda",
        ]
    }

    provisioner "online-rescue" {
        "enabled" = true
        "server" = "${online_server.dedibox.id}"
    }
}

Developing the Provisioner

If you wish to work on the provider, you'll first need Go installed on your machine (version 1.8+ is required). You'll also need to correctly setup a GOPATH, as well as adding $GOPATH/bin to your $PATH.

To compile the provider, run make build. This will build the provider and put the provider binary in the $GOPATH/bin directory.

$ make build
...
$ $GOPATH/bin/terraform-provisioner-online-rescue
...

In order to test the provider, you can simply run make test.

$ make test

In order to run the full suite of Acceptance tests, run make testacc.

Note: Acceptance tests create real resources, and often cost money to run.

$ make testacc

terraform-provisioner-online-rescue's People

Contributors

meyskens avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.