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.
 
 
 
 
 
 
James Phillips 1a117ba0a8
Makes the all segments query explict, and the default for `consul members`.
7 years ago
..
README.md
acl.go Adds a new /v1/acl/bootstrap API (#3349) 7 years ago
acl_test.go Adds a new /v1/acl/bootstrap API (#3349) 7 years ago
agent.go Makes the all segments query explict, and the default for `consul members`. 7 years ago
agent_test.go Organize segments for a cleaner split between enterprise and OSS 7 years ago
api.go Add rpc_listener option to segment config 7 years ago
api_test.go
catalog.go
catalog_test.go Adds open source side of network segments (feature is Enterprise-only). 7 years ago
coordinate.go Adds open source side of network segments (feature is Enterprise-only). 7 years ago
coordinate_test.go
event.go
event_test.go
health.go
health_test.go
kv.go
kv_test.go
lock.go
lock_test.go
operator.go
operator_area.go
operator_autopilot.go Add UpgradeVersionTag to autopilot config 7 years ago
operator_autopilot_test.go
operator_keyring.go
operator_keyring_test.go
operator_raft.go
operator_raft_test.go
operator_segment.go Change segment list endpoint in docs/client api 7 years ago
prepared_query.go
prepared_query_test.go
raw.go
semaphore.go
semaphore_test.go
session.go
session_test.go
snapshot.go
snapshot_test.go
status.go
status_test.go

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.6.0 are supported.

Documentation

The full documentation is available on Godoc

Usage

Below is an example of using the Consul client:

// Get a new client
client, err := api.NewClient(api.DefaultConfig())
if err != nil {
    panic(err)
}

// Get a handle to the KV API
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)