consul/api
John Landa 9eaa8eb026
dns token (#17936)
* dns token

fix whitespace for docs and comments

fix test cases

fix test cases

remove tabs in help text

Add changelog

Peering dns test

Peering dns test

Partial implementation of Peered DNS test

Swap to new topology lib

expose dns port for integration tests on client

remove partial test implementation

remove extra port exposure

remove changelog from the ent pr

Add dns token to set-agent-token switch

Add enterprise golden file

Use builtin/dns template in tests

Update ent dns policy

Update ent dns template test

remove local gen certs

fix templated policy specs

* add changelog

* go mod tidy
2023-09-20 15:50:06 -06:00
..
watch
.golangci.yml
LICENSE [COMPLIANCE] License changes (#18443) 2023-08-11 09:12:13 -04:00
README.md
acl.go [NET-5332] Add nomad server templated policy (#18888) 2023-09-20 12:10:55 -04:00
acl_test.go Add support for querying tokens by service name. (#18667) 2023-09-06 10:52:45 -05:00
agent.go dns token (#17936) 2023-09-20 15:50:06 -06:00
agent_test.go dns token (#17936) 2023-09-20 15:50:06 -06:00
api.go NET-4897 - update comment to include the current issue url from the go team. (#18263) 2023-07-24 21:27:19 +00:00
api_test.go
catalog.go
catalog_test.go Displays Consul version of each nodes in UI nodes section (#17754) 2023-07-12 13:34:39 -06:00
ce_test.go OSS -> CE (community edition) changes (#18517) 2023-08-22 09:46:03 -05:00
config_entry.go Added OpenTelemetry Access Logging Envoy extension (#18336) 2023-08-30 07:51:58 -07:00
config_entry_discoverychain.go
config_entry_discoverychain_test.go
config_entry_exports.go
config_entry_exports_test.go
config_entry_gateways.go NET-4984: Update APIGW Config Entries for JWT Auth (#18366) 2023-08-10 19:49:51 +00:00
config_entry_gateways_test.go OSS -> CE (community edition) changes (#18517) 2023-08-22 09:46:03 -05:00
config_entry_inline_certificate.go
config_entry_inline_certificate_test.go
config_entry_intentions.go
config_entry_intentions_test.go
config_entry_jwt_provider.go
config_entry_jwt_provider_test.go
config_entry_mesh.go
config_entry_rate_limit_ip.go
config_entry_routes.go NET-5530 Support response header modifiers on http-route config entry (#18646) 2023-09-08 14:04:56 -04:00
config_entry_routes_test.go APIGW: Update HTTPRouteConfigEntry for JWT Auth (#18422) 2023-08-10 21:23:42 +00:00
config_entry_sameness_group.go
config_entry_status.go Add the plumbing for APIGW JWT work (#18609) 2023-08-31 12:23:59 -04:00
config_entry_status_test.go
config_entry_test.go
connect.go
connect_ca.go
connect_ca_test.go
connect_intention.go
connect_intention_test.go
coordinate.go
coordinate_test.go
debug.go
debug_test.go
discovery_chain.go
discovery_chain_test.go
event.go
event_test.go
go.mod Net-2713/resource apply command (#18610) 2023-09-08 12:20:14 -04:00
go.sum Net-2713/resource apply command (#18610) 2023-09-08 12:20:14 -04:00
health.go Add TCP+TLS Healthchecks (#18381) 2023-09-05 13:34:44 -07:00
health_test.go
internal.go
internal_test.go
kv.go
kv_test.go
lock.go
lock_test.go
mock_api_test.go
namespace.go
namespace_test.go
operator.go
operator_area.go
operator_audit.go Add operator audit endpoint changes (#18899) 2023-09-19 13:05:06 -04:00
operator_autopilot.go
operator_autopilot_test.go
operator_keyring.go
operator_keyring_test.go
operator_license.go
operator_raft.go consul operator raft transfer-leader should send the id (#17107) 2023-09-15 14:38:59 -04:00
operator_raft_test.go consul operator raft transfer-leader should send the id (#17107) 2023-09-15 14:38:59 -04:00
operator_segment.go
operator_usage.go
operator_usage_test.go
partition.go
peering.go
peering_test.go
prepared_query.go add peering_commontopo tests [NET-3700] (#17951) 2023-07-18 16:41:30 -07:00
prepared_query_test.go
raw.go
resource.go delete command ready (#18679) 2023-09-13 11:48:40 -07:00
semaphore.go
semaphore_test.go
session.go
session_test.go
snapshot.go
snapshot_test.go
status.go
status_test.go
txn.go
txn_test.go Displays Consul version of each nodes in UI nodes section (#17754) 2023-07-12 13:34:39 -06:00

README.md

Consul API Client

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

The full documentation is available on Godoc.

Usage

Below is an example of using the Consul client. To run the example, you must first install Consul and Go.

To run the client API, create a new Go module.

go mod init consul-demo

Copy the example code into a file called main.go in the directory where the module is defined. As seen in the example, the Consul API is often imported with the alias capi.

package main

import (
	"fmt"

	capi "github.com/hashicorp/consul/api"
)

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

	// Get a handle to the KV API
	kv := client.KV()

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

	// Lookup the pair
	pair, _, err := kv.Get("REDIS_MAXCLIENTS", nil)
	if err != nil {
		panic(err)
	}
	fmt.Printf("KV: %v %s\n", pair.Key, pair.Value)
}

Install the Consul API dependency with go mod tidy.

In a separate terminal window, start a local Consul server.

consul agent -dev -node machine

Run the example.

go run .

You should get the following result printed to the terminal.

KV: REDIS_MAXCLIENTS 1000

After running the code, you can also view the values in the Consul UI on your local machine at http://localhost:8500/ui/dc1/kv