Requirements
Building The Provider
Clone repository to: $GOPATH/src/github.com/everonhq/terraform-provider-mongodb
$ mkdir -p $GOPATH/src/github.com/everonhq; cd $GOPATH/src/github.com/everonhq
$ git clone git@github.com:everonhq/terraform-provider-mongodb
Enter the provider directory, create the go.mod and build the provider
$ cd $GOPATH/src/github.com/everonhq/terraform-provider-mongodb
$ go mod init
$ make build
Install provider into Terraform plugins dir
$ cp ~/go/bin/terraform-provider-mongodb ~/.terraform.d/plugins/darwin_amd64/
Once code updated, install provider, and run example tf:
cd ..
make build
cp ~/go/bin/terraform-provider-mongodb ~/.terraform.d/plugins/darwin_amd64/
cd example
terraform init
terraform apply
Using the provider
Provider with auth enabled:
provider "mongodb" {
url = "mongodb://localhost:27017"
auth_database = "admin"
auth_username = "db-admin-user"
auth_password = var.admin_password
}
Then, create terraform.tfvars
with the password variable defined:
admin_password = "<provider login passsword>"
Provider without auth:
provider "mongodb" {
url = "mongodb://localhost:27017/test"
}
resource "mongodb_user" "user" {
database = "test"
username = "user"
password = "pass"
roles = ["read", "dbAdmin", "userAdmin"]
authentication_restrictions = jsonencode([{
clientSource = ["127.0.0.1"]
serverAddress = ["127.0.0.1"]
}])
}
Developing the Provider
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-provider-mongodb
...
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