mirror of
https://github.com/etcd-io/etcd.git
synced 2024-09-27 06:25:44 +00:00
v3client: implement clientv3.Auth interface (#12140)
This commit is contained in:
parent
cc656718fa
commit
7f27697df9
@ -121,6 +121,14 @@ func NewAuth(c *Client) Auth {
|
|||||||
return api
|
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) {
|
func (auth *authClient) AuthEnable(ctx context.Context) (*AuthEnableResponse, error) {
|
||||||
resp, err := auth.remote.AuthEnable(ctx, &pb.AuthEnableRequest{}, auth.callOpts...)
|
resp, err := auth.remote.AuthEnable(ctx, &pb.AuthEnableRequest{}, auth.callOpts...)
|
||||||
return (*AuthEnableResponse)(resp), toErr(ctx, err)
|
return (*AuthEnableResponse)(resp), toErr(ctx, err)
|
||||||
|
58
embed/auth_test.go
Normal file
58
embed/auth_test.go
Normal 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)
|
||||||
|
}
|
||||||
|
}
|
@ -49,7 +49,8 @@ func New(s *etcdserver.EtcdServer) *clientv3.Client {
|
|||||||
clc := adapter.ClusterServerToClusterClient(v3rpc.NewClusterServer(s))
|
clc := adapter.ClusterServerToClusterClient(v3rpc.NewClusterServer(s))
|
||||||
c.Cluster = clientv3.NewClusterFromClusterClient(clc, c)
|
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
|
return c
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user