Consul is a distributed, highly available, and data center aware solution to connect and configure applications across dynamic, distributed infrastructure.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Armon Dadgar 17d1c392e4 CHANGELOG update, gofmt 10 years ago
..
README.md
acl.go Revert "fixed: body not closed for non HTTP 200 responses" 10 years ago
acl_test.go
agent.go Merge pull request #625 from hashicorp/f-maintcmd 10 years ago
agent_test.go CHANGELOG update, gofmt 10 years ago
api.go Merge pull request #608 from imkira/fixBodyLeak 10 years ago
api_test.go Fixing merge conflict 10 years ago
catalog.go Revert "fixed: body not closed for non HTTP 200 responses" 10 years ago
catalog_test.go
event.go Revert "fixed: body not closed for non HTTP 200 responses" 10 years ago
event_test.go
health.go Revert "fixed: body not closed for non HTTP 200 responses" 10 years ago
health_test.go api: make node health test more reliable 10 years ago
kv.go Revert "fixed: body not closed for non HTTP 200 responses" 10 years ago
kv_test.go api: Add support for DeleteCAS 10 years ago
lock.go api: Fixing some comments 10 years ago
lock_test.go api: Detect conflicting existing values for lock/semaphore 10 years ago
semaphore.go api: Refactor to share session renew code 10 years ago
semaphore_test.go api: Detect conflicting existing values for lock/semaphore 10 years ago
session.go api: Refactor to share session renew code 10 years ago
session_test.go
status.go Revert "fixed: body not closed for non HTTP 200 responses" 10 years ago
status_test.go api: simple test for unix socket connectivity 10 years ago

README.md

Consul API client

This package provides the api package which attempts to provide programmatic access to the full Consul API.

Currently, all of the Consul APIs included in version 0.3 are supported.

Documentation

The full documentation is available on Godoc

Usage

Below is an example of using the Consul client:

// Get a new client, with KV endpoints
client, _ := api.NewClient(api.DefaultConfig())
kv := client.KV()

// PUT a new KV pair
p := &api.KVPair{Key: "foo", Value: []byte("test")}
_, err := kv.Put(p, nil)
if err != nil {
    panic(err)
}

// Lookup the pair
pair, _, err := kv.Get("foo", nil)
if err != nil {
    panic(err)
}
fmt.Printf("KV: %v", pair)