etcd/clientv3/config.go

63 lines
2.2 KiB
Go
Raw Normal View History

2016-05-13 06:50:58 +03:00
// Copyright 2016 The etcd Authors
2016-04-01 00:01:16 +03:00
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package clientv3
import (
"crypto/tls"
"time"
"golang.org/x/net/context"
"google.golang.org/grpc"
2016-04-01 00:01:16 +03:00
)
type Config struct {
// Endpoints is a list of URLs.
Endpoints []string `json:"endpoints"`
2016-04-01 00:01:16 +03:00
2016-09-21 19:10:25 +03:00
// AutoSyncInterval is the interval to update endpoints with its latest members.
// 0 disables auto-sync. By default auto-sync is disabled.
AutoSyncInterval time.Duration `json:"auto-sync-interval"`
2016-09-21 19:10:25 +03:00
2016-04-01 00:01:16 +03:00
// DialTimeout is the timeout for failing to establish a connection.
DialTimeout time.Duration `json:"dial-timeout"`
2016-04-01 00:01:16 +03:00
// DialKeepAliveTime is the time in seconds after which client pings the server to see if
// transport is alive.
DialKeepAliveTime time.Duration `json:"dial-keep-alive-time"`
// DialKeepAliveTimeout is the time in seconds that the client waits for a response for the
// keep-alive probe. If the response is not received in this time, the connection is closed.
DialKeepAliveTimeout time.Duration `json:"dial-keep-alive-timeout"`
2016-04-01 00:01:16 +03:00
// TLS holds the client secure credentials, if any.
TLS *tls.Config
2017-09-04 13:09:32 +03:00
// Username is a user name for authentication.
Username string `json:"username"`
2016-04-01 00:01:16 +03:00
// Password is a password for authentication.
Password string `json:"password"`
2017-02-17 00:18:59 +03:00
// RejectOldCluster when set will refuse to create a client against an outdated cluster.
RejectOldCluster bool `json:"reject-old-cluster"`
// DialOptions is a list of dial options for the grpc client (e.g., for interceptors).
DialOptions []grpc.DialOption
// Context is the default client context; it can be used to cancel grpc dial out and
// other operations that do not have an explicit context.
Context context.Context
2016-04-01 00:01:16 +03:00
}