v3client: implement clientv3.Auth interface (#12140)

release-3.5
Jan Kuri 2020-07-21 01:53:25 +02:00 committed by GitHub
parent cc656718fa
commit 7f27697df9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 68 additions and 1 deletions

View File

@ -121,6 +121,14 @@ func NewAuth(c *Client) Auth {
return api
}
func NewAuthFromAuthClient(remote pb.AuthClient, c *Client) Auth {
api := &authClient{remote: remote}
if c != nil {
api.callOpts = c.callOpts
}
return api
}
func (auth *authClient) AuthEnable(ctx context.Context) (*AuthEnableResponse, error) {
resp, err := auth.remote.AuthEnable(ctx, &pb.AuthEnableRequest{}, auth.callOpts...)
return (*AuthEnableResponse)(resp), toErr(ctx, err)

58
embed/auth_test.go Normal file
View File

@ -0,0 +1,58 @@
// Copyright 2020 The etcd Authors
//
// 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 embed
import (
"context"
"io/ioutil"
"os"
"testing"
"go.etcd.io/etcd/v3/etcdserver/api/v3client"
)
func TestEnableAuth(t *testing.T) {
tdir, err := ioutil.TempDir(os.TempDir(), "auth-test")
if err != nil {
t.Fatal(err)
}
defer os.RemoveAll(tdir)
cfg := NewConfig()
cfg.Dir = tdir
e, err := StartEtcd(cfg)
if err != nil {
t.Fatal(err)
}
defer e.Close()
client := v3client.New(e.Server)
defer client.Close()
_, err = client.RoleAdd(context.TODO(), "root")
if err != nil {
t.Fatal(err)
}
_, err = client.UserAdd(context.TODO(), "root", "root")
if err != nil {
t.Fatal(err)
}
_, err = client.UserGrantRole(context.TODO(), "root", "root")
if err != nil {
t.Fatal(err)
}
_, err = client.AuthEnable(context.TODO())
if err != nil {
t.Fatal(err)
}
}

View File

@ -49,7 +49,8 @@ func New(s *etcdserver.EtcdServer) *clientv3.Client {
clc := adapter.ClusterServerToClusterClient(v3rpc.NewClusterServer(s))
c.Cluster = clientv3.NewClusterFromClusterClient(clc, c)
// TODO: implement clientv3.Auth interface?
a := adapter.AuthServerToAuthClient(v3rpc.NewAuthServer(s))
c.Auth = clientv3.NewAuthFromAuthClient(a, c)
return c
}