瀏覽代碼

chore(proto): generat protos

Mustafa Arici 5 年之前
父節點
當前提交
64c03b3896
共有 4 個文件被更改,包括 451 次插入322 次删除
  1. 61 44
      api/pb/auth.pb.go
  2. 144 101
      api/pb/network.pb.go
  3. 139 99
      api/pb/user.pb.go
  4. 107 78
      api/pb/vpn.pb.go

+ 61 - 44
api/pb/auth.pb.go

@@ -3,14 +3,15 @@
 
 package pb
 
-import proto "github.com/golang/protobuf/proto"
-import fmt "fmt"
-import math "math"
-import _ "google.golang.org/genproto/googleapis/api/annotations"
-
 import (
-	context "golang.org/x/net/context"
+	context "context"
+	fmt "fmt"
+	proto "github.com/golang/protobuf/proto"
+	_ "google.golang.org/genproto/googleapis/api/annotations"
 	grpc "google.golang.org/grpc"
+	codes "google.golang.org/grpc/codes"
+	status "google.golang.org/grpc/status"
+	math "math"
 )
 
 // Reference imports to suppress errors if they are not otherwise used.
@@ -22,7 +23,7 @@ var _ = math.Inf
 // is compatible with the proto package it is being compiled against.
 // A compilation error at this line likely means your copy of the
 // proto package needs to be updated.
-const _ = proto.ProtoPackageIsVersion2 // please upgrade the proto package
+const _ = proto.ProtoPackageIsVersion3 // please upgrade the proto package
 
 type AuthStatusRequest struct {
 	XXX_NoUnkeyedLiteral struct{} `json:"-"`
@@ -34,16 +35,17 @@ func (m *AuthStatusRequest) Reset()         { *m = AuthStatusRequest{} }
 func (m *AuthStatusRequest) String() string { return proto.CompactTextString(m) }
 func (*AuthStatusRequest) ProtoMessage()    {}
 func (*AuthStatusRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_auth_5d9157b05cb925f8, []int{0}
+	return fileDescriptor_8bbd6f3875b0e874, []int{0}
 }
+
 func (m *AuthStatusRequest) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_AuthStatusRequest.Unmarshal(m, b)
 }
 func (m *AuthStatusRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_AuthStatusRequest.Marshal(b, m, deterministic)
 }
-func (dst *AuthStatusRequest) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_AuthStatusRequest.Merge(dst, src)
+func (m *AuthStatusRequest) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_AuthStatusRequest.Merge(m, src)
 }
 func (m *AuthStatusRequest) XXX_Size() int {
 	return xxx_messageInfo_AuthStatusRequest.Size(m)
@@ -66,16 +68,17 @@ func (m *AuthAuthenticateRequest) Reset()         { *m = AuthAuthenticateRequest
 func (m *AuthAuthenticateRequest) String() string { return proto.CompactTextString(m) }
 func (*AuthAuthenticateRequest) ProtoMessage()    {}
 func (*AuthAuthenticateRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_auth_5d9157b05cb925f8, []int{1}
+	return fileDescriptor_8bbd6f3875b0e874, []int{1}
 }
+
 func (m *AuthAuthenticateRequest) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_AuthAuthenticateRequest.Unmarshal(m, b)
 }
 func (m *AuthAuthenticateRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_AuthAuthenticateRequest.Marshal(b, m, deterministic)
 }
-func (dst *AuthAuthenticateRequest) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_AuthAuthenticateRequest.Merge(dst, src)
+func (m *AuthAuthenticateRequest) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_AuthAuthenticateRequest.Merge(m, src)
 }
 func (m *AuthAuthenticateRequest) XXX_Size() int {
 	return xxx_messageInfo_AuthAuthenticateRequest.Size(m)
@@ -112,16 +115,17 @@ func (m *AuthStatusResponse) Reset()         { *m = AuthStatusResponse{} }
 func (m *AuthStatusResponse) String() string { return proto.CompactTextString(m) }
 func (*AuthStatusResponse) ProtoMessage()    {}
 func (*AuthStatusResponse) Descriptor() ([]byte, []int) {
-	return fileDescriptor_auth_5d9157b05cb925f8, []int{2}
+	return fileDescriptor_8bbd6f3875b0e874, []int{2}
 }
+
 func (m *AuthStatusResponse) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_AuthStatusResponse.Unmarshal(m, b)
 }
 func (m *AuthStatusResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_AuthStatusResponse.Marshal(b, m, deterministic)
 }
-func (dst *AuthStatusResponse) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_AuthStatusResponse.Merge(dst, src)
+func (m *AuthStatusResponse) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_AuthStatusResponse.Merge(m, src)
 }
 func (m *AuthStatusResponse) XXX_Size() int {
 	return xxx_messageInfo_AuthStatusResponse.Size(m)
@@ -157,16 +161,17 @@ func (m *AuthAuthenticateResponse) Reset()         { *m = AuthAuthenticateRespon
 func (m *AuthAuthenticateResponse) String() string { return proto.CompactTextString(m) }
 func (*AuthAuthenticateResponse) ProtoMessage()    {}
 func (*AuthAuthenticateResponse) Descriptor() ([]byte, []int) {
-	return fileDescriptor_auth_5d9157b05cb925f8, []int{3}
+	return fileDescriptor_8bbd6f3875b0e874, []int{3}
 }
+
 func (m *AuthAuthenticateResponse) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_AuthAuthenticateResponse.Unmarshal(m, b)
 }
 func (m *AuthAuthenticateResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_AuthAuthenticateResponse.Marshal(b, m, deterministic)
 }
-func (dst *AuthAuthenticateResponse) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_AuthAuthenticateResponse.Merge(dst, src)
+func (m *AuthAuthenticateResponse) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_AuthAuthenticateResponse.Merge(m, src)
 }
 func (m *AuthAuthenticateResponse) XXX_Size() int {
 	return xxx_messageInfo_AuthAuthenticateResponse.Size(m)
@@ -191,6 +196,32 @@ func init() {
 	proto.RegisterType((*AuthAuthenticateResponse)(nil), "pb.AuthAuthenticateResponse")
 }
 
+func init() { proto.RegisterFile("auth.proto", fileDescriptor_8bbd6f3875b0e874) }
+
+var fileDescriptor_8bbd6f3875b0e874 = []byte{
+	// 306 bytes of a gzipped FileDescriptorProto
+	0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x6c, 0x51, 0x41, 0x4e, 0x2a, 0x41,
+	0x10, 0xcd, 0x90, 0xff, 0x11, 0x0b, 0x37, 0x36, 0x22, 0x38, 0x10, 0x63, 0x26, 0x2e, 0xd4, 0x05,
+	0xa3, 0xb8, 0x73, 0xe7, 0x11, 0x1c, 0x35, 0x71, 0x67, 0x1a, 0xac, 0xc0, 0x44, 0xed, 0x1a, 0xbb,
+	0x6a, 0x70, 0xef, 0x15, 0x3c, 0x9a, 0x1e, 0xc1, 0x83, 0x98, 0xee, 0x1e, 0xcc, 0x28, 0x2c, 0x3a,
+	0xe9, 0x57, 0xaf, 0xea, 0xbd, 0x97, 0x2a, 0x00, 0x5d, 0xca, 0x7c, 0x54, 0x58, 0x12, 0x52, 0x8d,
+	0x62, 0x12, 0x0f, 0x67, 0x44, 0xb3, 0x27, 0x4c, 0x75, 0x91, 0xa7, 0xda, 0x18, 0x12, 0x2d, 0x39,
+	0x19, 0x0e, 0x1d, 0x31, 0x94, 0x8c, 0x36, 0xfc, 0x93, 0x0e, 0x6c, 0x5f, 0x96, 0x32, 0xbf, 0x16,
+	0x2d, 0x25, 0x67, 0xf8, 0x52, 0x22, 0x4b, 0x72, 0x05, 0x3d, 0x57, 0x74, 0x0f, 0x8d, 0xe4, 0x53,
+	0x2d, 0x58, 0x51, 0x2a, 0x86, 0x96, 0x9b, 0x36, 0xfa, 0x19, 0xfb, 0xd1, 0x41, 0x74, 0xb4, 0x99,
+	0xfd, 0x60, 0xc7, 0x15, 0x9a, 0xf9, 0x95, 0xec, 0x43, 0xbf, 0x11, 0xb8, 0x25, 0x4e, 0xee, 0x40,
+	0xd5, 0x7d, 0xb8, 0x20, 0xc3, 0xa8, 0x8e, 0xe1, 0x9f, 0x9b, 0xf6, 0x4a, 0xed, 0x71, 0x77, 0x54,
+	0x4c, 0x46, 0xb7, 0x8c, 0x76, 0xc9, 0x07, 0xe0, 0x5b, 0x54, 0x0f, 0x36, 0x72, 0xbe, 0xb7, 0x44,
+	0xe2, 0xb5, 0x5b, 0x59, 0x33, 0xe7, 0x8c, 0x48, 0x92, 0x53, 0xe8, 0xaf, 0x86, 0xad, 0xf4, 0x77,
+	0xe0, 0xbf, 0xd0, 0x23, 0x9a, 0x2a, 0x6a, 0x00, 0xe3, 0xcf, 0x08, 0xda, 0x3e, 0x0c, 0xda, 0x45,
+	0x3e, 0x45, 0x75, 0x03, 0xcd, 0x90, 0x4b, 0xf9, 0x04, 0x2b, 0xfb, 0x88, 0x77, 0xff, 0x96, 0x83,
+	0x7c, 0x32, 0x78, 0xfb, 0xf8, 0x7a, 0x6f, 0x74, 0x55, 0xc7, 0x2f, 0x7a, 0x71, 0x96, 0xba, 0x33,
+	0xa4, 0x1c, 0xb4, 0x08, 0xb6, 0xea, 0x99, 0xd4, 0x60, 0x29, 0xb2, 0x66, 0xad, 0xf1, 0x70, 0x3d,
+	0x59, 0xf9, 0x1c, 0x7a, 0x9f, 0xfd, 0x64, 0xef, 0x97, 0x8f, 0xae, 0xb5, 0x5e, 0x44, 0x27, 0x93,
+	0xa6, 0xbf, 0xe8, 0xf9, 0x77, 0x00, 0x00, 0x00, 0xff, 0xff, 0x87, 0xd8, 0x13, 0x0a, 0x0d, 0x02,
+	0x00, 0x00,
+}
+
 // Reference imports to suppress errors if they are not otherwise used.
 var _ context.Context
 var _ grpc.ClientConn
@@ -239,6 +270,17 @@ type AuthServiceServer interface {
 	Authenticate(context.Context, *AuthAuthenticateRequest) (*AuthAuthenticateResponse, error)
 }
 
+// UnimplementedAuthServiceServer can be embedded to have forward compatible implementations.
+type UnimplementedAuthServiceServer struct {
+}
+
+func (*UnimplementedAuthServiceServer) Status(ctx context.Context, req *AuthStatusRequest) (*AuthStatusResponse, error) {
+	return nil, status.Errorf(codes.Unimplemented, "method Status not implemented")
+}
+func (*UnimplementedAuthServiceServer) Authenticate(ctx context.Context, req *AuthAuthenticateRequest) (*AuthAuthenticateResponse, error) {
+	return nil, status.Errorf(codes.Unimplemented, "method Authenticate not implemented")
+}
+
 func RegisterAuthServiceServer(s *grpc.Server, srv AuthServiceServer) {
 	s.RegisterService(&_AuthService_serviceDesc, srv)
 }
@@ -295,28 +337,3 @@ var _AuthService_serviceDesc = grpc.ServiceDesc{
 	Streams:  []grpc.StreamDesc{},
 	Metadata: "auth.proto",
 }
-
-func init() { proto.RegisterFile("auth.proto", fileDescriptor_auth_5d9157b05cb925f8) }
-
-var fileDescriptor_auth_5d9157b05cb925f8 = []byte{
-	// 303 bytes of a gzipped FileDescriptorProto
-	0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0x6c, 0x51, 0x41, 0x4e, 0xc3, 0x30,
-	0x10, 0x54, 0x22, 0x08, 0x65, 0xcb, 0x05, 0x97, 0xd2, 0x90, 0x56, 0x08, 0x59, 0x1c, 0x80, 0x43,
-	0x02, 0xe5, 0xc6, 0x8d, 0x27, 0x10, 0x40, 0xe2, 0x86, 0x9c, 0x62, 0x15, 0x0b, 0xf0, 0x9a, 0xd8,
-	0x29, 0x77, 0xbe, 0xc0, 0xd3, 0xe0, 0x09, 0x3c, 0x84, 0xd8, 0x4e, 0x50, 0xa0, 0x3d, 0x44, 0xca,
-	0x78, 0x66, 0x67, 0x46, 0xbb, 0x00, 0xac, 0x32, 0x8f, 0xa9, 0x2a, 0xd1, 0x20, 0x09, 0x55, 0x91,
-	0x4c, 0xe6, 0x88, 0xf3, 0x67, 0x9e, 0x31, 0x25, 0x32, 0x26, 0x25, 0x1a, 0x66, 0x04, 0x4a, 0xed,
-	0x15, 0x09, 0x54, 0x9a, 0x97, 0xfe, 0x9f, 0x0e, 0x60, 0xfb, 0xb2, 0x9e, 0xbd, 0xae, 0x15, 0x95,
-	0xce, 0xf9, 0x6b, 0xc5, 0xb5, 0xa1, 0x57, 0x30, 0xb2, 0x8f, 0xf6, 0xe3, 0xd2, 0x88, 0x19, 0x33,
-	0xbc, 0xa1, 0x48, 0x02, 0x3d, 0x3b, 0x2d, 0xd9, 0x0b, 0x8f, 0x83, 0x83, 0xe0, 0x68, 0x33, 0xff,
-	0xc5, 0x96, 0x53, 0x4c, 0xeb, 0x37, 0x2c, 0x1f, 0xe2, 0xd0, 0x73, 0x2d, 0xa6, 0x77, 0x40, 0xba,
-	0x39, 0x5a, 0xd5, 0x75, 0x38, 0x39, 0x86, 0x35, 0x3b, 0xed, 0x9c, 0xfa, 0xd3, 0x61, 0xaa, 0x8a,
-	0xf4, 0xb6, 0xc6, 0x2d, 0xef, 0x81, 0x93, 0x90, 0x11, 0x6c, 0x08, 0x7d, 0x5f, 0x22, 0x1a, 0xe7,
-	0xdd, 0xcb, 0x23, 0xa1, 0xf3, 0x1a, 0xd1, 0x53, 0x88, 0x97, 0xcb, 0x36, 0xfe, 0x3b, 0xb0, 0x6e,
-	0xf0, 0x89, 0xcb, 0xa6, 0xaa, 0x07, 0xd3, 0xaf, 0x00, 0xfa, 0xae, 0x0c, 0x2f, 0x17, 0x62, 0xc6,
-	0xc9, 0x0d, 0x44, 0xbe, 0x17, 0x71, 0x0d, 0x96, 0xf6, 0x91, 0xec, 0xfe, 0x7f, 0xf6, 0xf6, 0x74,
-	0xfc, 0xfe, 0xf9, 0xfd, 0x11, 0x0e, 0xc9, 0xc0, 0x2d, 0x7a, 0x71, 0x96, 0xd9, 0x33, 0x64, 0xda,
-	0x7b, 0x21, 0x6c, 0x75, 0x3b, 0x91, 0x71, 0x6b, 0xb2, 0x62, 0xad, 0xc9, 0x64, 0x35, 0xd9, 0xe4,
-	0x1c, 0xba, 0x9c, 0x7d, 0xba, 0xf7, 0x27, 0x87, 0x75, 0xa4, 0x17, 0xc1, 0x49, 0x11, 0xb9, 0x8b,
-	0x9e, 0xff, 0x04, 0x00, 0x00, 0xff, 0xff, 0x87, 0xd8, 0x13, 0x0a, 0x0d, 0x02, 0x00, 0x00,
-}

+ 144 - 101
api/pb/network.pb.go

@@ -3,14 +3,15 @@
 
 package pb
 
-import proto "github.com/golang/protobuf/proto"
-import fmt "fmt"
-import math "math"
-import _ "google.golang.org/genproto/googleapis/api/annotations"
-
 import (
-	context "golang.org/x/net/context"
+	context "context"
+	fmt "fmt"
+	proto "github.com/golang/protobuf/proto"
+	_ "google.golang.org/genproto/googleapis/api/annotations"
 	grpc "google.golang.org/grpc"
+	codes "google.golang.org/grpc/codes"
+	status "google.golang.org/grpc/status"
+	math "math"
 )
 
 // Reference imports to suppress errors if they are not otherwise used.
@@ -22,7 +23,7 @@ var _ = math.Inf
 // is compatible with the proto package it is being compiled against.
 // A compilation error at this line likely means your copy of the
 // proto package needs to be updated.
-const _ = proto.ProtoPackageIsVersion2 // please upgrade the proto package
+const _ = proto.ProtoPackageIsVersion3 // please upgrade the proto package
 
 type NetworkCreateRequest struct {
 	Name                 string   `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"`
@@ -38,16 +39,17 @@ func (m *NetworkCreateRequest) Reset()         { *m = NetworkCreateRequest{} }
 func (m *NetworkCreateRequest) String() string { return proto.CompactTextString(m) }
 func (*NetworkCreateRequest) ProtoMessage()    {}
 func (*NetworkCreateRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_network_34cf09007f6526a1, []int{0}
+	return fileDescriptor_8571034d60397816, []int{0}
 }
+
 func (m *NetworkCreateRequest) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_NetworkCreateRequest.Unmarshal(m, b)
 }
 func (m *NetworkCreateRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_NetworkCreateRequest.Marshal(b, m, deterministic)
 }
-func (dst *NetworkCreateRequest) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_NetworkCreateRequest.Merge(dst, src)
+func (m *NetworkCreateRequest) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_NetworkCreateRequest.Merge(m, src)
 }
 func (m *NetworkCreateRequest) XXX_Size() int {
 	return xxx_messageInfo_NetworkCreateRequest.Size(m)
@@ -96,16 +98,17 @@ func (m *NetworkListRequest) Reset()         { *m = NetworkListRequest{} }
 func (m *NetworkListRequest) String() string { return proto.CompactTextString(m) }
 func (*NetworkListRequest) ProtoMessage()    {}
 func (*NetworkListRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_network_34cf09007f6526a1, []int{1}
+	return fileDescriptor_8571034d60397816, []int{1}
 }
+
 func (m *NetworkListRequest) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_NetworkListRequest.Unmarshal(m, b)
 }
 func (m *NetworkListRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_NetworkListRequest.Marshal(b, m, deterministic)
 }
-func (dst *NetworkListRequest) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_NetworkListRequest.Merge(dst, src)
+func (m *NetworkListRequest) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_NetworkListRequest.Merge(m, src)
 }
 func (m *NetworkListRequest) XXX_Size() int {
 	return xxx_messageInfo_NetworkListRequest.Size(m)
@@ -127,16 +130,17 @@ func (m *NetworkDeleteRequest) Reset()         { *m = NetworkDeleteRequest{} }
 func (m *NetworkDeleteRequest) String() string { return proto.CompactTextString(m) }
 func (*NetworkDeleteRequest) ProtoMessage()    {}
 func (*NetworkDeleteRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_network_34cf09007f6526a1, []int{2}
+	return fileDescriptor_8571034d60397816, []int{2}
 }
+
 func (m *NetworkDeleteRequest) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_NetworkDeleteRequest.Unmarshal(m, b)
 }
 func (m *NetworkDeleteRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_NetworkDeleteRequest.Marshal(b, m, deterministic)
 }
-func (dst *NetworkDeleteRequest) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_NetworkDeleteRequest.Merge(dst, src)
+func (m *NetworkDeleteRequest) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_NetworkDeleteRequest.Merge(m, src)
 }
 func (m *NetworkDeleteRequest) XXX_Size() int {
 	return xxx_messageInfo_NetworkDeleteRequest.Size(m)
@@ -164,16 +168,17 @@ func (m *NetworkGetAllTypesRequest) Reset()         { *m = NetworkGetAllTypesReq
 func (m *NetworkGetAllTypesRequest) String() string { return proto.CompactTextString(m) }
 func (*NetworkGetAllTypesRequest) ProtoMessage()    {}
 func (*NetworkGetAllTypesRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_network_34cf09007f6526a1, []int{3}
+	return fileDescriptor_8571034d60397816, []int{3}
 }
+
 func (m *NetworkGetAllTypesRequest) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_NetworkGetAllTypesRequest.Unmarshal(m, b)
 }
 func (m *NetworkGetAllTypesRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_NetworkGetAllTypesRequest.Marshal(b, m, deterministic)
 }
-func (dst *NetworkGetAllTypesRequest) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_NetworkGetAllTypesRequest.Merge(dst, src)
+func (m *NetworkGetAllTypesRequest) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_NetworkGetAllTypesRequest.Merge(m, src)
 }
 func (m *NetworkGetAllTypesRequest) XXX_Size() int {
 	return xxx_messageInfo_NetworkGetAllTypesRequest.Size(m)
@@ -196,16 +201,17 @@ func (m *NetworkAssociateRequest) Reset()         { *m = NetworkAssociateRequest
 func (m *NetworkAssociateRequest) String() string { return proto.CompactTextString(m) }
 func (*NetworkAssociateRequest) ProtoMessage()    {}
 func (*NetworkAssociateRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_network_34cf09007f6526a1, []int{4}
+	return fileDescriptor_8571034d60397816, []int{4}
 }
+
 func (m *NetworkAssociateRequest) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_NetworkAssociateRequest.Unmarshal(m, b)
 }
 func (m *NetworkAssociateRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_NetworkAssociateRequest.Marshal(b, m, deterministic)
 }
-func (dst *NetworkAssociateRequest) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_NetworkAssociateRequest.Merge(dst, src)
+func (m *NetworkAssociateRequest) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_NetworkAssociateRequest.Merge(m, src)
 }
 func (m *NetworkAssociateRequest) XXX_Size() int {
 	return xxx_messageInfo_NetworkAssociateRequest.Size(m)
@@ -242,16 +248,17 @@ func (m *NetworkDissociateRequest) Reset()         { *m = NetworkDissociateReque
 func (m *NetworkDissociateRequest) String() string { return proto.CompactTextString(m) }
 func (*NetworkDissociateRequest) ProtoMessage()    {}
 func (*NetworkDissociateRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_network_34cf09007f6526a1, []int{5}
+	return fileDescriptor_8571034d60397816, []int{5}
 }
+
 func (m *NetworkDissociateRequest) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_NetworkDissociateRequest.Unmarshal(m, b)
 }
 func (m *NetworkDissociateRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_NetworkDissociateRequest.Marshal(b, m, deterministic)
 }
-func (dst *NetworkDissociateRequest) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_NetworkDissociateRequest.Merge(dst, src)
+func (m *NetworkDissociateRequest) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_NetworkDissociateRequest.Merge(m, src)
 }
 func (m *NetworkDissociateRequest) XXX_Size() int {
 	return xxx_messageInfo_NetworkDissociateRequest.Size(m)
@@ -287,16 +294,17 @@ func (m *NetworkGetAssociatedUsersRequest) Reset()         { *m = NetworkGetAsso
 func (m *NetworkGetAssociatedUsersRequest) String() string { return proto.CompactTextString(m) }
 func (*NetworkGetAssociatedUsersRequest) ProtoMessage()    {}
 func (*NetworkGetAssociatedUsersRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_network_34cf09007f6526a1, []int{6}
+	return fileDescriptor_8571034d60397816, []int{6}
 }
+
 func (m *NetworkGetAssociatedUsersRequest) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_NetworkGetAssociatedUsersRequest.Unmarshal(m, b)
 }
 func (m *NetworkGetAssociatedUsersRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_NetworkGetAssociatedUsersRequest.Marshal(b, m, deterministic)
 }
-func (dst *NetworkGetAssociatedUsersRequest) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_NetworkGetAssociatedUsersRequest.Merge(dst, src)
+func (m *NetworkGetAssociatedUsersRequest) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_NetworkGetAssociatedUsersRequest.Merge(m, src)
 }
 func (m *NetworkGetAssociatedUsersRequest) XXX_Size() int {
 	return xxx_messageInfo_NetworkGetAssociatedUsersRequest.Size(m)
@@ -330,16 +338,17 @@ func (m *Network) Reset()         { *m = Network{} }
 func (m *Network) String() string { return proto.CompactTextString(m) }
 func (*Network) ProtoMessage()    {}
 func (*Network) Descriptor() ([]byte, []int) {
-	return fileDescriptor_network_34cf09007f6526a1, []int{7}
+	return fileDescriptor_8571034d60397816, []int{7}
 }
+
 func (m *Network) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_Network.Unmarshal(m, b)
 }
 func (m *Network) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_Network.Marshal(b, m, deterministic)
 }
-func (dst *Network) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_Network.Merge(dst, src)
+func (m *Network) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_Network.Merge(m, src)
 }
 func (m *Network) XXX_Size() int {
 	return xxx_messageInfo_Network.Size(m)
@@ -404,16 +413,17 @@ func (m *NetworkType) Reset()         { *m = NetworkType{} }
 func (m *NetworkType) String() string { return proto.CompactTextString(m) }
 func (*NetworkType) ProtoMessage()    {}
 func (*NetworkType) Descriptor() ([]byte, []int) {
-	return fileDescriptor_network_34cf09007f6526a1, []int{8}
+	return fileDescriptor_8571034d60397816, []int{8}
 }
+
 func (m *NetworkType) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_NetworkType.Unmarshal(m, b)
 }
 func (m *NetworkType) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_NetworkType.Marshal(b, m, deterministic)
 }
-func (dst *NetworkType) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_NetworkType.Merge(dst, src)
+func (m *NetworkType) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_NetworkType.Merge(m, src)
 }
 func (m *NetworkType) XXX_Size() int {
 	return xxx_messageInfo_NetworkType.Size(m)
@@ -449,16 +459,17 @@ func (m *NetworkCreateResponse) Reset()         { *m = NetworkCreateResponse{} }
 func (m *NetworkCreateResponse) String() string { return proto.CompactTextString(m) }
 func (*NetworkCreateResponse) ProtoMessage()    {}
 func (*NetworkCreateResponse) Descriptor() ([]byte, []int) {
-	return fileDescriptor_network_34cf09007f6526a1, []int{9}
+	return fileDescriptor_8571034d60397816, []int{9}
 }
+
 func (m *NetworkCreateResponse) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_NetworkCreateResponse.Unmarshal(m, b)
 }
 func (m *NetworkCreateResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_NetworkCreateResponse.Marshal(b, m, deterministic)
 }
-func (dst *NetworkCreateResponse) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_NetworkCreateResponse.Merge(dst, src)
+func (m *NetworkCreateResponse) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_NetworkCreateResponse.Merge(m, src)
 }
 func (m *NetworkCreateResponse) XXX_Size() int {
 	return xxx_messageInfo_NetworkCreateResponse.Size(m)
@@ -487,16 +498,17 @@ func (m *NetworkListResponse) Reset()         { *m = NetworkListResponse{} }
 func (m *NetworkListResponse) String() string { return proto.CompactTextString(m) }
 func (*NetworkListResponse) ProtoMessage()    {}
 func (*NetworkListResponse) Descriptor() ([]byte, []int) {
-	return fileDescriptor_network_34cf09007f6526a1, []int{10}
+	return fileDescriptor_8571034d60397816, []int{10}
 }
+
 func (m *NetworkListResponse) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_NetworkListResponse.Unmarshal(m, b)
 }
 func (m *NetworkListResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_NetworkListResponse.Marshal(b, m, deterministic)
 }
-func (dst *NetworkListResponse) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_NetworkListResponse.Merge(dst, src)
+func (m *NetworkListResponse) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_NetworkListResponse.Merge(m, src)
 }
 func (m *NetworkListResponse) XXX_Size() int {
 	return xxx_messageInfo_NetworkListResponse.Size(m)
@@ -525,16 +537,17 @@ func (m *NetworkDeleteResponse) Reset()         { *m = NetworkDeleteResponse{} }
 func (m *NetworkDeleteResponse) String() string { return proto.CompactTextString(m) }
 func (*NetworkDeleteResponse) ProtoMessage()    {}
 func (*NetworkDeleteResponse) Descriptor() ([]byte, []int) {
-	return fileDescriptor_network_34cf09007f6526a1, []int{11}
+	return fileDescriptor_8571034d60397816, []int{11}
 }
+
 func (m *NetworkDeleteResponse) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_NetworkDeleteResponse.Unmarshal(m, b)
 }
 func (m *NetworkDeleteResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_NetworkDeleteResponse.Marshal(b, m, deterministic)
 }
-func (dst *NetworkDeleteResponse) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_NetworkDeleteResponse.Merge(dst, src)
+func (m *NetworkDeleteResponse) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_NetworkDeleteResponse.Merge(m, src)
 }
 func (m *NetworkDeleteResponse) XXX_Size() int {
 	return xxx_messageInfo_NetworkDeleteResponse.Size(m)
@@ -563,16 +576,17 @@ func (m *NetworkGetAllTypesResponse) Reset()         { *m = NetworkGetAllTypesRe
 func (m *NetworkGetAllTypesResponse) String() string { return proto.CompactTextString(m) }
 func (*NetworkGetAllTypesResponse) ProtoMessage()    {}
 func (*NetworkGetAllTypesResponse) Descriptor() ([]byte, []int) {
-	return fileDescriptor_network_34cf09007f6526a1, []int{12}
+	return fileDescriptor_8571034d60397816, []int{12}
 }
+
 func (m *NetworkGetAllTypesResponse) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_NetworkGetAllTypesResponse.Unmarshal(m, b)
 }
 func (m *NetworkGetAllTypesResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_NetworkGetAllTypesResponse.Marshal(b, m, deterministic)
 }
-func (dst *NetworkGetAllTypesResponse) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_NetworkGetAllTypesResponse.Merge(dst, src)
+func (m *NetworkGetAllTypesResponse) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_NetworkGetAllTypesResponse.Merge(m, src)
 }
 func (m *NetworkGetAllTypesResponse) XXX_Size() int {
 	return xxx_messageInfo_NetworkGetAllTypesResponse.Size(m)
@@ -600,16 +614,17 @@ func (m *NetworkAssociateResponse) Reset()         { *m = NetworkAssociateRespon
 func (m *NetworkAssociateResponse) String() string { return proto.CompactTextString(m) }
 func (*NetworkAssociateResponse) ProtoMessage()    {}
 func (*NetworkAssociateResponse) Descriptor() ([]byte, []int) {
-	return fileDescriptor_network_34cf09007f6526a1, []int{13}
+	return fileDescriptor_8571034d60397816, []int{13}
 }
+
 func (m *NetworkAssociateResponse) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_NetworkAssociateResponse.Unmarshal(m, b)
 }
 func (m *NetworkAssociateResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_NetworkAssociateResponse.Marshal(b, m, deterministic)
 }
-func (dst *NetworkAssociateResponse) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_NetworkAssociateResponse.Merge(dst, src)
+func (m *NetworkAssociateResponse) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_NetworkAssociateResponse.Merge(m, src)
 }
 func (m *NetworkAssociateResponse) XXX_Size() int {
 	return xxx_messageInfo_NetworkAssociateResponse.Size(m)
@@ -630,16 +645,17 @@ func (m *NetworkDissociateResponse) Reset()         { *m = NetworkDissociateResp
 func (m *NetworkDissociateResponse) String() string { return proto.CompactTextString(m) }
 func (*NetworkDissociateResponse) ProtoMessage()    {}
 func (*NetworkDissociateResponse) Descriptor() ([]byte, []int) {
-	return fileDescriptor_network_34cf09007f6526a1, []int{14}
+	return fileDescriptor_8571034d60397816, []int{14}
 }
+
 func (m *NetworkDissociateResponse) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_NetworkDissociateResponse.Unmarshal(m, b)
 }
 func (m *NetworkDissociateResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_NetworkDissociateResponse.Marshal(b, m, deterministic)
 }
-func (dst *NetworkDissociateResponse) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_NetworkDissociateResponse.Merge(dst, src)
+func (m *NetworkDissociateResponse) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_NetworkDissociateResponse.Merge(m, src)
 }
 func (m *NetworkDissociateResponse) XXX_Size() int {
 	return xxx_messageInfo_NetworkDissociateResponse.Size(m)
@@ -661,16 +677,17 @@ func (m *NetworkGetAssociatedUsersResponse) Reset()         { *m = NetworkGetAss
 func (m *NetworkGetAssociatedUsersResponse) String() string { return proto.CompactTextString(m) }
 func (*NetworkGetAssociatedUsersResponse) ProtoMessage()    {}
 func (*NetworkGetAssociatedUsersResponse) Descriptor() ([]byte, []int) {
-	return fileDescriptor_network_34cf09007f6526a1, []int{15}
+	return fileDescriptor_8571034d60397816, []int{15}
 }
+
 func (m *NetworkGetAssociatedUsersResponse) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_NetworkGetAssociatedUsersResponse.Unmarshal(m, b)
 }
 func (m *NetworkGetAssociatedUsersResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_NetworkGetAssociatedUsersResponse.Marshal(b, m, deterministic)
 }
-func (dst *NetworkGetAssociatedUsersResponse) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_NetworkGetAssociatedUsersResponse.Merge(dst, src)
+func (m *NetworkGetAssociatedUsersResponse) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_NetworkGetAssociatedUsersResponse.Merge(m, src)
 }
 func (m *NetworkGetAssociatedUsersResponse) XXX_Size() int {
 	return xxx_messageInfo_NetworkGetAssociatedUsersResponse.Size(m)
@@ -707,6 +724,52 @@ func init() {
 	proto.RegisterType((*NetworkGetAssociatedUsersResponse)(nil), "pb.NetworkGetAssociatedUsersResponse")
 }
 
+func init() { proto.RegisterFile("network.proto", fileDescriptor_8571034d60397816) }
+
+var fileDescriptor_8571034d60397816 = []byte{
+	// 640 bytes of a gzipped FileDescriptorProto
+	0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xa4, 0x55, 0x4d, 0x6f, 0xda, 0x40,
+	0x10, 0x95, 0x81, 0x90, 0x30, 0xa8, 0x1f, 0xda, 0x50, 0x62, 0x0c, 0xa4, 0x64, 0x0b, 0x6a, 0xc4,
+	0x01, 0x94, 0x54, 0xea, 0xa1, 0x87, 0x48, 0x88, 0x4a, 0x55, 0xab, 0xaa, 0x07, 0xda, 0x9c, 0x13,
+	0x83, 0x57, 0xc8, 0xaa, 0x6b, 0x3b, 0xde, 0x85, 0x2a, 0xd7, 0xde, 0xdb, 0x4b, 0x7f, 0x45, 0x7f,
+	0x4f, 0xff, 0x42, 0x7f, 0x48, 0xb5, 0xeb, 0xb1, 0x59, 0x9b, 0x8f, 0x28, 0xca, 0x6d, 0x99, 0x99,
+	0x7d, 0xef, 0x79, 0xdf, 0xd3, 0x00, 0x8f, 0x7c, 0x26, 0xbe, 0x07, 0xd1, 0xd7, 0x41, 0x18, 0x05,
+	0x22, 0x20, 0x85, 0x70, 0x6a, 0xb5, 0xe6, 0x41, 0x30, 0xf7, 0xd8, 0xd0, 0x0e, 0xdd, 0xa1, 0xed,
+	0xfb, 0x81, 0xb0, 0x85, 0x1b, 0xf8, 0x3c, 0x9e, 0xa0, 0x0e, 0xd4, 0x3e, 0xc5, 0x57, 0xc6, 0x11,
+	0xb3, 0x05, 0x9b, 0xb0, 0x9b, 0x05, 0xe3, 0x82, 0x10, 0x28, 0xf9, 0xf6, 0x37, 0x66, 0x1a, 0x1d,
+	0xe3, 0xb4, 0x32, 0x51, 0x67, 0x59, 0x9b, 0xb9, 0x4e, 0x64, 0x16, 0xe2, 0x9a, 0x3c, 0xcb, 0x9a,
+	0xb8, 0x0d, 0x99, 0x59, 0x8c, 0x6b, 0xf2, 0x4c, 0x9e, 0x42, 0x71, 0xe9, 0xda, 0x66, 0x49, 0x95,
+	0xe4, 0x91, 0xd6, 0x80, 0x20, 0xcb, 0x47, 0x97, 0x0b, 0xe4, 0xa0, 0xfd, 0x94, 0xfb, 0x2d, 0xf3,
+	0xd8, 0x4e, 0x6e, 0xda, 0x84, 0x06, 0xce, 0xbe, 0x63, 0x62, 0xe4, 0x79, 0x5f, 0x6e, 0x43, 0xc6,
+	0x13, 0xa0, 0xf7, 0x70, 0x84, 0xcd, 0x11, 0xe7, 0xc1, 0xcc, 0xbd, 0xe3, 0x3b, 0x2c, 0x38, 0x58,
+	0x70, 0x16, 0xa9, 0x7a, 0xfc, 0x2d, 0xe9, 0x6f, 0xfa, 0x01, 0xcc, 0x44, 0x93, 0xfb, 0x50, 0xac,
+	0xd7, 0xd0, 0xd1, 0x34, 0x27, 0x68, 0xce, 0x25, 0x67, 0x11, 0xdf, 0xf5, 0xad, 0x7f, 0x0c, 0xd8,
+	0xc7, 0x8b, 0x0f, 0xf2, 0xa1, 0x0d, 0x30, 0x53, 0xa6, 0x3a, 0x57, 0xb6, 0x40, 0x3b, 0x2a, 0x58,
+	0x19, 0x09, 0x72, 0x06, 0x35, 0x3b, 0x15, 0x75, 0x95, 0xa8, 0xe6, 0xe6, 0x5e, 0xa7, 0x78, 0x5a,
+	0x99, 0x1c, 0xda, 0x19, 0xc1, 0xaa, 0x95, 0x38, 0x5b, 0x5e, 0x39, 0x3b, 0x86, 0x2a, 0x4a, 0x95,
+	0x8e, 0xa4, 0x32, 0x0c, 0x4d, 0x46, 0x07, 0xaa, 0x0e, 0xe3, 0xb3, 0xc8, 0x0d, 0x65, 0xf0, 0x50,
+	0xb5, 0x5e, 0xa2, 0x17, 0xf0, 0x2c, 0x17, 0x42, 0x1e, 0x06, 0x3e, 0x67, 0xa4, 0x07, 0xfb, 0x18,
+	0x68, 0x85, 0x58, 0x3d, 0xaf, 0x0e, 0xc2, 0xe9, 0x00, 0x67, 0x27, 0x49, 0x8f, 0x5e, 0xc0, 0x61,
+	0x26, 0x5e, 0x78, 0xfb, 0x25, 0x1c, 0xe0, 0x04, 0x37, 0x8d, 0x4e, 0x31, 0x7f, 0x3d, 0x6d, 0x6a,
+	0xfc, 0x49, 0x10, 0xef, 0xc7, 0x3f, 0x06, 0x6b, 0x53, 0x38, 0x53, 0x90, 0x3d, 0xf9, 0x0e, 0x89,
+	0x86, 0x27, 0x1a, 0x84, 0x1c, 0x9c, 0xc4, 0x5d, 0x6a, 0xa5, 0xc9, 0xd3, 0x42, 0x1c, 0x43, 0x68,
+	0xe9, 0xd7, 0x53, 0x89, 0xcd, 0x11, 0x9c, 0xec, 0x88, 0x19, 0x8a, 0x68, 0x41, 0x65, 0xe5, 0xb0,
+	0xa1, 0x1c, 0x5e, 0x15, 0xce, 0x7f, 0x95, 0xe1, 0x31, 0x62, 0x7c, 0x66, 0xd1, 0xd2, 0x9d, 0x31,
+	0x72, 0x0d, 0xe5, 0xd8, 0x0c, 0x62, 0x6a, 0x82, 0x33, 0x4b, 0xc2, 0x6a, 0x6c, 0xe8, 0xa0, 0xa8,
+	0x93, 0x1f, 0x7f, 0xff, 0xfd, 0x2e, 0x34, 0x69, 0x5d, 0xed, 0x9d, 0xe5, 0xd9, 0x10, 0xdf, 0x6a,
+	0x18, 0xe7, 0xef, 0x8d, 0xd1, 0x27, 0x97, 0x50, 0x92, 0x76, 0x91, 0xba, 0x86, 0xa2, 0xad, 0x07,
+	0xeb, 0x68, 0xad, 0x8e, 0xd8, 0x2d, 0x85, 0x5d, 0x27, 0xb5, 0x3c, 0xb6, 0x27, 0xe1, 0xae, 0xa1,
+	0x1c, 0xbb, 0x98, 0x11, 0x9e, 0xd9, 0x30, 0x19, 0xe1, 0x59, 0xcb, 0xb7, 0x0b, 0x77, 0xd4, 0x9c,
+	0x14, 0x7e, 0x03, 0x55, 0xcd, 0x67, 0xd2, 0xd6, 0xc0, 0xd6, 0x97, 0x93, 0x75, 0xbc, 0xad, 0x8d,
+	0x84, 0x2f, 0x14, 0x61, 0x9b, 0x34, 0xf3, 0x84, 0x73, 0x26, 0x6c, 0xcf, 0x53, 0xe1, 0x20, 0x3f,
+	0x0d, 0x20, 0xeb, 0xee, 0x92, 0x6e, 0x0e, 0x7b, 0xe3, 0x8e, 0xb1, 0x7a, 0x77, 0x4c, 0xa1, 0x90,
+	0xbe, 0x12, 0xd2, 0x25, 0x74, 0x93, 0x90, 0xf4, 0xce, 0x42, 0x11, 0x7b, 0x50, 0x49, 0x61, 0x48,
+	0x53, 0xc3, 0xcf, 0x2f, 0x60, 0xab, 0xb5, 0xb9, 0x89, 0x9c, 0x5d, 0xc5, 0x79, 0x4c, 0x1b, 0x79,
+	0xce, 0x94, 0x50, 0x3e, 0x78, 0x08, 0xb0, 0xca, 0x3d, 0xd1, 0x11, 0xd7, 0x96, 0xb4, 0xd5, 0xde,
+	0xd2, 0x45, 0xc2, 0x9e, 0x22, 0x7c, 0x4e, 0xad, 0x35, 0x7b, 0x5d, 0x8d, 0x71, 0x5a, 0x56, 0xff,
+	0x8e, 0xaf, 0xfe, 0x07, 0x00, 0x00, 0xff, 0xff, 0xab, 0x14, 0xfe, 0x39, 0x50, 0x07, 0x00, 0x00,
+}
+
 // Reference imports to suppress errors if they are not otherwise used.
 var _ context.Context
 var _ grpc.ClientConn
@@ -810,6 +873,32 @@ type NetworkServiceServer interface {
 	Dissociate(context.Context, *NetworkDissociateRequest) (*NetworkDissociateResponse, error)
 }
 
+// UnimplementedNetworkServiceServer can be embedded to have forward compatible implementations.
+type UnimplementedNetworkServiceServer struct {
+}
+
+func (*UnimplementedNetworkServiceServer) Create(ctx context.Context, req *NetworkCreateRequest) (*NetworkCreateResponse, error) {
+	return nil, status.Errorf(codes.Unimplemented, "method Create not implemented")
+}
+func (*UnimplementedNetworkServiceServer) List(ctx context.Context, req *NetworkListRequest) (*NetworkListResponse, error) {
+	return nil, status.Errorf(codes.Unimplemented, "method List not implemented")
+}
+func (*UnimplementedNetworkServiceServer) Delete(ctx context.Context, req *NetworkDeleteRequest) (*NetworkDeleteResponse, error) {
+	return nil, status.Errorf(codes.Unimplemented, "method Delete not implemented")
+}
+func (*UnimplementedNetworkServiceServer) GetAllTypes(ctx context.Context, req *NetworkGetAllTypesRequest) (*NetworkGetAllTypesResponse, error) {
+	return nil, status.Errorf(codes.Unimplemented, "method GetAllTypes not implemented")
+}
+func (*UnimplementedNetworkServiceServer) GetAssociatedUsers(ctx context.Context, req *NetworkGetAssociatedUsersRequest) (*NetworkGetAssociatedUsersResponse, error) {
+	return nil, status.Errorf(codes.Unimplemented, "method GetAssociatedUsers not implemented")
+}
+func (*UnimplementedNetworkServiceServer) Associate(ctx context.Context, req *NetworkAssociateRequest) (*NetworkAssociateResponse, error) {
+	return nil, status.Errorf(codes.Unimplemented, "method Associate not implemented")
+}
+func (*UnimplementedNetworkServiceServer) Dissociate(ctx context.Context, req *NetworkDissociateRequest) (*NetworkDissociateResponse, error) {
+	return nil, status.Errorf(codes.Unimplemented, "method Dissociate not implemented")
+}
+
 func RegisterNetworkServiceServer(s *grpc.Server, srv NetworkServiceServer) {
 	s.RegisterService(&_NetworkService_serviceDesc, srv)
 }
@@ -976,49 +1065,3 @@ var _NetworkService_serviceDesc = grpc.ServiceDesc{
 	Streams:  []grpc.StreamDesc{},
 	Metadata: "network.proto",
 }
-
-func init() { proto.RegisterFile("network.proto", fileDescriptor_network_34cf09007f6526a1) }
-
-var fileDescriptor_network_34cf09007f6526a1 = []byte{
-	// 637 bytes of a gzipped FileDescriptorProto
-	0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xa4, 0x55, 0xcd, 0x8e, 0xd2, 0x50,
-	0x18, 0x4d, 0x81, 0x61, 0x86, 0x8f, 0xf8, 0x93, 0x3b, 0xc8, 0x94, 0x02, 0x23, 0x73, 0x85, 0x68,
-	0x58, 0x40, 0x66, 0x4c, 0x5c, 0xb8, 0x30, 0x21, 0x98, 0x18, 0x8d, 0x71, 0x81, 0xce, 0x7a, 0x2c,
-	0xf4, 0x86, 0x34, 0x56, 0xda, 0xe9, 0xbd, 0x60, 0xdc, 0xba, 0xd7, 0x8d, 0x4f, 0xe1, 0xf3, 0xf8,
-	0x0a, 0x3e, 0x88, 0xbd, 0xb7, 0x5f, 0xcb, 0x6d, 0xf9, 0x99, 0x4c, 0x66, 0x57, 0xbe, 0x9f, 0x73,
-	0x4e, 0x7b, 0x4e, 0x3e, 0xe0, 0xde, 0x82, 0x89, 0x6f, 0x7e, 0xf8, 0x65, 0x10, 0x84, 0xbe, 0xf0,
-	0x49, 0x21, 0x98, 0x5a, 0xad, 0xb9, 0xef, 0xcf, 0x3d, 0x36, 0xb4, 0x03, 0x77, 0x68, 0x2f, 0x16,
-	0xbe, 0xb0, 0x85, 0xeb, 0x2f, 0x78, 0x3c, 0x41, 0x1d, 0xa8, 0x7d, 0x88, 0x57, 0xc6, 0x21, 0xb3,
-	0x05, 0x9b, 0xb0, 0xeb, 0x25, 0xe3, 0x82, 0x10, 0x28, 0x2d, 0xec, 0xaf, 0xcc, 0x34, 0x3a, 0xc6,
-	0xb3, 0xca, 0x44, 0x3d, 0xcb, 0xda, 0xcc, 0x75, 0x42, 0xb3, 0x10, 0xd7, 0xe4, 0xb3, 0xac, 0x89,
-	0xef, 0x01, 0x33, 0x8b, 0x71, 0x4d, 0x3e, 0x93, 0x87, 0x50, 0x5c, 0xb9, 0xb6, 0x59, 0x52, 0x25,
-	0xf9, 0x48, 0x6b, 0x40, 0x90, 0xe5, 0xbd, 0xcb, 0x05, 0x72, 0xd0, 0x7e, 0xca, 0xfd, 0x9a, 0x79,
-	0x6c, 0x2f, 0x37, 0x6d, 0x42, 0x03, 0x67, 0xdf, 0x30, 0x31, 0xf2, 0xbc, 0x4f, 0x11, 0x11, 0x4f,
-	0x80, 0xde, 0xc2, 0x09, 0x36, 0x47, 0x9c, 0xfb, 0x33, 0xf7, 0x86, 0xf7, 0xb0, 0xe0, 0x68, 0xc9,
-	0x59, 0xa8, 0xea, 0xf1, 0xbb, 0xa4, 0xbf, 0xe9, 0x3b, 0x30, 0x13, 0x4d, 0xee, 0x5d, 0xb1, 0x5e,
-	0x40, 0x47, 0xd3, 0x9c, 0xa0, 0x39, 0x97, 0x51, 0x9f, 0xef, 0x7b, 0xd7, 0x3f, 0x06, 0x1c, 0xe2,
-	0xe2, 0x9d, 0x7c, 0x68, 0x03, 0xcc, 0x94, 0xa9, 0xce, 0x95, 0x2d, 0xd0, 0x8e, 0x0a, 0x56, 0x46,
-	0x82, 0x9c, 0x43, 0xcd, 0x4e, 0x45, 0x5d, 0x25, 0xaa, 0xb9, 0x79, 0xd0, 0x29, 0x46, 0x83, 0xc7,
-	0x76, 0x46, 0xb0, 0x6a, 0x25, 0xce, 0x96, 0xd7, 0xce, 0x8e, 0xa1, 0x8a, 0x52, 0xa5, 0x23, 0xa9,
-	0x0c, 0x43, 0x93, 0xd1, 0x81, 0xaa, 0xc3, 0xf8, 0x2c, 0x74, 0x03, 0x19, 0x3c, 0x54, 0xad, 0x97,
-	0xe8, 0x2b, 0x78, 0x94, 0x0b, 0x21, 0x0f, 0xa2, 0x88, 0x32, 0xd2, 0x83, 0x43, 0x0c, 0xb4, 0x42,
-	0xac, 0x5e, 0x54, 0x07, 0xc1, 0x74, 0x80, 0xb3, 0x93, 0xa4, 0x17, 0xed, 0x1f, 0x67, 0xe2, 0x85,
-	0xdb, 0x4f, 0xe1, 0x08, 0x27, 0x78, 0xb4, 0x5e, 0xcc, 0xaf, 0xa7, 0x4d, 0x8d, 0x3f, 0x09, 0xe2,
-	0xed, 0xf8, 0xc7, 0x60, 0x6d, 0x0b, 0x67, 0x0a, 0x72, 0x20, 0xbf, 0x43, 0xa2, 0xe1, 0x81, 0x06,
-	0x21, 0x07, 0x27, 0x71, 0x97, 0x5a, 0x69, 0xf2, 0xb4, 0x10, 0xc7, 0x10, 0x5a, 0xfa, 0xf5, 0x54,
-	0x62, 0x73, 0x04, 0x67, 0x7b, 0x62, 0x86, 0x22, 0x5a, 0x50, 0x59, 0x3b, 0x6c, 0x28, 0x87, 0xd7,
-	0x85, 0x8b, 0x5f, 0x65, 0xb8, 0x8f, 0x18, 0x1f, 0x59, 0xb8, 0x72, 0x67, 0x8c, 0x7c, 0x86, 0x72,
-	0x6c, 0x06, 0x31, 0x35, 0xc1, 0x99, 0x23, 0x61, 0x35, 0xb6, 0x74, 0x50, 0xd4, 0xd9, 0x8f, 0xbf,
-	0xff, 0x7e, 0x17, 0x9a, 0xb4, 0xae, 0xee, 0xce, 0xea, 0x7c, 0x88, 0xdf, 0x6a, 0x18, 0xe7, 0xef,
-	0xa5, 0xd1, 0x27, 0x97, 0x50, 0x92, 0x76, 0x91, 0xba, 0x86, 0xa2, 0x9d, 0x07, 0xeb, 0x64, 0xa3,
-	0x8e, 0xd8, 0x2d, 0x85, 0x5d, 0x27, 0xb5, 0x3c, 0xb6, 0x27, 0xe1, 0x22, 0xe1, 0xb1, 0x8b, 0x19,
-	0xe1, 0x99, 0x0b, 0x93, 0x11, 0x9e, 0xb5, 0x7c, 0xb7, 0x70, 0x47, 0xcd, 0x49, 0xe1, 0xd7, 0x50,
-	0xd5, 0x7c, 0x26, 0x6d, 0x0d, 0x6c, 0xf3, 0x38, 0x59, 0xa7, 0xbb, 0xda, 0x48, 0xf8, 0x44, 0x11,
-	0xb6, 0x49, 0x33, 0x4f, 0x38, 0x67, 0xc2, 0xf6, 0x3c, 0x15, 0x0e, 0xf2, 0xd3, 0x00, 0xb2, 0xe9,
-	0x2e, 0xe9, 0xe6, 0xb0, 0xb7, 0xde, 0x18, 0xab, 0x77, 0xc3, 0x14, 0x0a, 0xe9, 0x2b, 0x21, 0x5d,
-	0x42, 0xb7, 0x09, 0x49, 0x77, 0x96, 0x8a, 0xd8, 0x83, 0x4a, 0x0a, 0x43, 0x9a, 0x1a, 0x7e, 0xfe,
-	0x00, 0x5b, 0xad, 0xed, 0x4d, 0xe4, 0xec, 0x2a, 0xce, 0x53, 0xda, 0xc8, 0x73, 0xa6, 0x84, 0xf2,
-	0x83, 0x07, 0x00, 0xeb, 0xdc, 0x13, 0x1d, 0x71, 0xe3, 0x48, 0x5b, 0xed, 0x1d, 0x5d, 0x24, 0xec,
-	0x29, 0xc2, 0xc7, 0xd4, 0xda, 0xb0, 0xd7, 0xd5, 0x18, 0xa7, 0x65, 0xf5, 0xef, 0xf8, 0xfc, 0x7f,
-	0x00, 0x00, 0x00, 0xff, 0xff, 0xab, 0x14, 0xfe, 0x39, 0x50, 0x07, 0x00, 0x00,
-}

+ 139 - 99
api/pb/user.pb.go

@@ -3,14 +3,15 @@
 
 package pb
 
-import proto "github.com/golang/protobuf/proto"
-import fmt "fmt"
-import math "math"
-import _ "google.golang.org/genproto/googleapis/api/annotations"
-
 import (
-	context "golang.org/x/net/context"
+	context "context"
+	fmt "fmt"
+	proto "github.com/golang/protobuf/proto"
+	_ "google.golang.org/genproto/googleapis/api/annotations"
 	grpc "google.golang.org/grpc"
+	codes "google.golang.org/grpc/codes"
+	status "google.golang.org/grpc/status"
+	math "math"
 )
 
 // Reference imports to suppress errors if they are not otherwise used.
@@ -22,7 +23,7 @@ var _ = math.Inf
 // is compatible with the proto package it is being compiled against.
 // A compilation error at this line likely means your copy of the
 // proto package needs to be updated.
-const _ = proto.ProtoPackageIsVersion2 // please upgrade the proto package
+const _ = proto.ProtoPackageIsVersion3 // please upgrade the proto package
 
 type UserUpdateRequest_GWPref int32
 
@@ -37,6 +38,7 @@ var UserUpdateRequest_GWPref_name = map[int32]string{
 	1: "NOGW",
 	2: "GW",
 }
+
 var UserUpdateRequest_GWPref_value = map[string]int32{
 	"NOPREF": 0,
 	"NOGW":   1,
@@ -46,8 +48,9 @@ var UserUpdateRequest_GWPref_value = map[string]int32{
 func (x UserUpdateRequest_GWPref) String() string {
 	return proto.EnumName(UserUpdateRequest_GWPref_name, int32(x))
 }
+
 func (UserUpdateRequest_GWPref) EnumDescriptor() ([]byte, []int) {
-	return fileDescriptor_user_32c669a016e64e35, []int{2, 0}
+	return fileDescriptor_116e343673f7ffaf, []int{2, 0}
 }
 
 type UserUpdateRequest_StaticPref int32
@@ -63,6 +66,7 @@ var UserUpdateRequest_StaticPref_name = map[int32]string{
 	1: "NOSTATIC",
 	2: "STATIC",
 }
+
 var UserUpdateRequest_StaticPref_value = map[string]int32{
 	"NOPREFSTATIC": 0,
 	"NOSTATIC":     1,
@@ -72,8 +76,9 @@ var UserUpdateRequest_StaticPref_value = map[string]int32{
 func (x UserUpdateRequest_StaticPref) String() string {
 	return proto.EnumName(UserUpdateRequest_StaticPref_name, int32(x))
 }
+
 func (UserUpdateRequest_StaticPref) EnumDescriptor() ([]byte, []int) {
-	return fileDescriptor_user_32c669a016e64e35, []int{2, 1}
+	return fileDescriptor_116e343673f7ffaf, []int{2, 1}
 }
 
 type UserUpdateRequest_AdminPref int32
@@ -89,6 +94,7 @@ var UserUpdateRequest_AdminPref_name = map[int32]string{
 	1: "NOADMIN",
 	2: "ADMIN",
 }
+
 var UserUpdateRequest_AdminPref_value = map[string]int32{
 	"NOPREFADMIN": 0,
 	"NOADMIN":     1,
@@ -98,8 +104,9 @@ var UserUpdateRequest_AdminPref_value = map[string]int32{
 func (x UserUpdateRequest_AdminPref) String() string {
 	return proto.EnumName(UserUpdateRequest_AdminPref_name, int32(x))
 }
+
 func (UserUpdateRequest_AdminPref) EnumDescriptor() ([]byte, []int) {
-	return fileDescriptor_user_32c669a016e64e35, []int{2, 2}
+	return fileDescriptor_116e343673f7ffaf, []int{2, 2}
 }
 
 type UserListRequest struct {
@@ -112,16 +119,17 @@ func (m *UserListRequest) Reset()         { *m = UserListRequest{} }
 func (m *UserListRequest) String() string { return proto.CompactTextString(m) }
 func (*UserListRequest) ProtoMessage()    {}
 func (*UserListRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_user_32c669a016e64e35, []int{0}
+	return fileDescriptor_116e343673f7ffaf, []int{0}
 }
+
 func (m *UserListRequest) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_UserListRequest.Unmarshal(m, b)
 }
 func (m *UserListRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_UserListRequest.Marshal(b, m, deterministic)
 }
-func (dst *UserListRequest) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_UserListRequest.Merge(dst, src)
+func (m *UserListRequest) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_UserListRequest.Merge(m, src)
 }
 func (m *UserListRequest) XXX_Size() int {
 	return xxx_messageInfo_UserListRequest.Size(m)
@@ -148,16 +156,17 @@ func (m *UserCreateRequest) Reset()         { *m = UserCreateRequest{} }
 func (m *UserCreateRequest) String() string { return proto.CompactTextString(m) }
 func (*UserCreateRequest) ProtoMessage()    {}
 func (*UserCreateRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_user_32c669a016e64e35, []int{1}
+	return fileDescriptor_116e343673f7ffaf, []int{1}
 }
+
 func (m *UserCreateRequest) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_UserCreateRequest.Unmarshal(m, b)
 }
 func (m *UserCreateRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_UserCreateRequest.Marshal(b, m, deterministic)
 }
-func (dst *UserCreateRequest) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_UserCreateRequest.Merge(dst, src)
+func (m *UserCreateRequest) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_UserCreateRequest.Merge(m, src)
 }
 func (m *UserCreateRequest) XXX_Size() int {
 	return xxx_messageInfo_UserCreateRequest.Size(m)
@@ -227,16 +236,17 @@ func (m *UserUpdateRequest) Reset()         { *m = UserUpdateRequest{} }
 func (m *UserUpdateRequest) String() string { return proto.CompactTextString(m) }
 func (*UserUpdateRequest) ProtoMessage()    {}
 func (*UserUpdateRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_user_32c669a016e64e35, []int{2}
+	return fileDescriptor_116e343673f7ffaf, []int{2}
 }
+
 func (m *UserUpdateRequest) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_UserUpdateRequest.Unmarshal(m, b)
 }
 func (m *UserUpdateRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_UserUpdateRequest.Marshal(b, m, deterministic)
 }
-func (dst *UserUpdateRequest) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_UserUpdateRequest.Merge(dst, src)
+func (m *UserUpdateRequest) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_UserUpdateRequest.Merge(m, src)
 }
 func (m *UserUpdateRequest) XXX_Size() int {
 	return xxx_messageInfo_UserUpdateRequest.Size(m)
@@ -307,16 +317,17 @@ func (m *UserDeleteRequest) Reset()         { *m = UserDeleteRequest{} }
 func (m *UserDeleteRequest) String() string { return proto.CompactTextString(m) }
 func (*UserDeleteRequest) ProtoMessage()    {}
 func (*UserDeleteRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_user_32c669a016e64e35, []int{3}
+	return fileDescriptor_116e343673f7ffaf, []int{3}
 }
+
 func (m *UserDeleteRequest) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_UserDeleteRequest.Unmarshal(m, b)
 }
 func (m *UserDeleteRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_UserDeleteRequest.Marshal(b, m, deterministic)
 }
-func (dst *UserDeleteRequest) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_UserDeleteRequest.Merge(dst, src)
+func (m *UserDeleteRequest) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_UserDeleteRequest.Merge(m, src)
 }
 func (m *UserDeleteRequest) XXX_Size() int {
 	return xxx_messageInfo_UserDeleteRequest.Size(m)
@@ -345,16 +356,17 @@ func (m *UserRenewRequest) Reset()         { *m = UserRenewRequest{} }
 func (m *UserRenewRequest) String() string { return proto.CompactTextString(m) }
 func (*UserRenewRequest) ProtoMessage()    {}
 func (*UserRenewRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_user_32c669a016e64e35, []int{4}
+	return fileDescriptor_116e343673f7ffaf, []int{4}
 }
+
 func (m *UserRenewRequest) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_UserRenewRequest.Unmarshal(m, b)
 }
 func (m *UserRenewRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_UserRenewRequest.Marshal(b, m, deterministic)
 }
-func (dst *UserRenewRequest) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_UserRenewRequest.Merge(dst, src)
+func (m *UserRenewRequest) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_UserRenewRequest.Merge(m, src)
 }
 func (m *UserRenewRequest) XXX_Size() int {
 	return xxx_messageInfo_UserRenewRequest.Size(m)
@@ -383,16 +395,17 @@ func (m *UserGenConfigRequest) Reset()         { *m = UserGenConfigRequest{} }
 func (m *UserGenConfigRequest) String() string { return proto.CompactTextString(m) }
 func (*UserGenConfigRequest) ProtoMessage()    {}
 func (*UserGenConfigRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_user_32c669a016e64e35, []int{5}
+	return fileDescriptor_116e343673f7ffaf, []int{5}
 }
+
 func (m *UserGenConfigRequest) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_UserGenConfigRequest.Unmarshal(m, b)
 }
 func (m *UserGenConfigRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_UserGenConfigRequest.Marshal(b, m, deterministic)
 }
-func (dst *UserGenConfigRequest) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_UserGenConfigRequest.Merge(dst, src)
+func (m *UserGenConfigRequest) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_UserGenConfigRequest.Merge(m, src)
 }
 func (m *UserGenConfigRequest) XXX_Size() int {
 	return xxx_messageInfo_UserGenConfigRequest.Size(m)
@@ -421,16 +434,17 @@ func (m *UserResponse) Reset()         { *m = UserResponse{} }
 func (m *UserResponse) String() string { return proto.CompactTextString(m) }
 func (*UserResponse) ProtoMessage()    {}
 func (*UserResponse) Descriptor() ([]byte, []int) {
-	return fileDescriptor_user_32c669a016e64e35, []int{6}
+	return fileDescriptor_116e343673f7ffaf, []int{6}
 }
+
 func (m *UserResponse) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_UserResponse.Unmarshal(m, b)
 }
 func (m *UserResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_UserResponse.Marshal(b, m, deterministic)
 }
-func (dst *UserResponse) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_UserResponse.Merge(dst, src)
+func (m *UserResponse) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_UserResponse.Merge(m, src)
 }
 func (m *UserResponse) XXX_Size() int {
 	return xxx_messageInfo_UserResponse.Size(m)
@@ -472,16 +486,17 @@ func (m *UserResponse_User) Reset()         { *m = UserResponse_User{} }
 func (m *UserResponse_User) String() string { return proto.CompactTextString(m) }
 func (*UserResponse_User) ProtoMessage()    {}
 func (*UserResponse_User) Descriptor() ([]byte, []int) {
-	return fileDescriptor_user_32c669a016e64e35, []int{6, 0}
+	return fileDescriptor_116e343673f7ffaf, []int{6, 0}
 }
+
 func (m *UserResponse_User) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_UserResponse_User.Unmarshal(m, b)
 }
 func (m *UserResponse_User) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_UserResponse_User.Marshal(b, m, deterministic)
 }
-func (dst *UserResponse_User) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_UserResponse_User.Merge(dst, src)
+func (m *UserResponse_User) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_UserResponse_User.Merge(m, src)
 }
 func (m *UserResponse_User) XXX_Size() int {
 	return xxx_messageInfo_UserResponse_User.Size(m)
@@ -601,16 +616,17 @@ func (m *UserGenConfigResponse) Reset()         { *m = UserGenConfigResponse{} }
 func (m *UserGenConfigResponse) String() string { return proto.CompactTextString(m) }
 func (*UserGenConfigResponse) ProtoMessage()    {}
 func (*UserGenConfigResponse) Descriptor() ([]byte, []int) {
-	return fileDescriptor_user_32c669a016e64e35, []int{7}
+	return fileDescriptor_116e343673f7ffaf, []int{7}
 }
+
 func (m *UserGenConfigResponse) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_UserGenConfigResponse.Unmarshal(m, b)
 }
 func (m *UserGenConfigResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_UserGenConfigResponse.Marshal(b, m, deterministic)
 }
-func (dst *UserGenConfigResponse) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_UserGenConfigResponse.Merge(dst, src)
+func (m *UserGenConfigResponse) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_UserGenConfigResponse.Merge(m, src)
 }
 func (m *UserGenConfigResponse) XXX_Size() int {
 	return xxx_messageInfo_UserGenConfigResponse.Size(m)
@@ -629,6 +645,9 @@ func (m *UserGenConfigResponse) GetClientConfig() string {
 }
 
 func init() {
+	proto.RegisterEnum("pb.UserUpdateRequest_GWPref", UserUpdateRequest_GWPref_name, UserUpdateRequest_GWPref_value)
+	proto.RegisterEnum("pb.UserUpdateRequest_StaticPref", UserUpdateRequest_StaticPref_name, UserUpdateRequest_StaticPref_value)
+	proto.RegisterEnum("pb.UserUpdateRequest_AdminPref", UserUpdateRequest_AdminPref_name, UserUpdateRequest_AdminPref_value)
 	proto.RegisterType((*UserListRequest)(nil), "pb.UserListRequest")
 	proto.RegisterType((*UserCreateRequest)(nil), "pb.UserCreateRequest")
 	proto.RegisterType((*UserUpdateRequest)(nil), "pb.UserUpdateRequest")
@@ -638,9 +657,66 @@ func init() {
 	proto.RegisterType((*UserResponse)(nil), "pb.UserResponse")
 	proto.RegisterType((*UserResponse_User)(nil), "pb.UserResponse.User")
 	proto.RegisterType((*UserGenConfigResponse)(nil), "pb.UserGenConfigResponse")
-	proto.RegisterEnum("pb.UserUpdateRequest_GWPref", UserUpdateRequest_GWPref_name, UserUpdateRequest_GWPref_value)
-	proto.RegisterEnum("pb.UserUpdateRequest_StaticPref", UserUpdateRequest_StaticPref_name, UserUpdateRequest_StaticPref_value)
-	proto.RegisterEnum("pb.UserUpdateRequest_AdminPref", UserUpdateRequest_AdminPref_name, UserUpdateRequest_AdminPref_value)
+}
+
+func init() { proto.RegisterFile("user.proto", fileDescriptor_116e343673f7ffaf) }
+
+var fileDescriptor_116e343673f7ffaf = []byte{
+	// 853 bytes of a gzipped FileDescriptorProto
+	0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x95, 0x4f, 0x6f, 0xe3, 0x44,
+	0x14, 0xc0, 0xeb, 0xfc, 0x71, 0xe2, 0xe7, 0xb4, 0x75, 0xa7, 0x2d, 0xeb, 0x86, 0x5d, 0xc8, 0x1a,
+	0x01, 0xd1, 0x22, 0x25, 0x50, 0xf6, 0x80, 0x56, 0x08, 0x29, 0xea, 0x42, 0xa8, 0x04, 0xee, 0xe2,
+	0xec, 0xaa, 0x47, 0xcb, 0xb1, 0x5f, 0xc3, 0x48, 0xe9, 0xd8, 0xcc, 0x4c, 0x13, 0xb8, 0x22, 0xf1,
+	0x09, 0xf8, 0x2e, 0x1c, 0xf8, 0x1a, 0x1c, 0xf8, 0x02, 0x7c, 0x08, 0x8e, 0x68, 0x66, 0x9c, 0x64,
+	0x93, 0x66, 0x51, 0x0e, 0x7b, 0x9b, 0xf7, 0xef, 0x37, 0xcf, 0x6f, 0xde, 0x7b, 0x06, 0xb8, 0x13,
+	0xc8, 0x7b, 0x05, 0xcf, 0x65, 0x4e, 0x2a, 0xc5, 0xb8, 0xfd, 0x70, 0x92, 0xe7, 0x93, 0x29, 0xf6,
+	0x93, 0x82, 0xf6, 0x13, 0xc6, 0x72, 0x99, 0x48, 0x9a, 0x33, 0x61, 0x3c, 0x82, 0x23, 0x38, 0x7c,
+	0x25, 0x90, 0x7f, 0x47, 0x85, 0x8c, 0xf0, 0xa7, 0x3b, 0x14, 0x32, 0xf8, 0xc3, 0x82, 0x23, 0xa5,
+	0xbb, 0xe0, 0x98, 0x48, 0x2c, 0xb5, 0xa4, 0x0d, 0x4d, 0x05, 0x66, 0xc9, 0x2d, 0xfa, 0x56, 0xc7,
+	0xea, 0x3a, 0xd1, 0x52, 0x56, 0xb6, 0x22, 0x11, 0x62, 0x9e, 0xf3, 0xcc, 0xaf, 0x18, 0xdb, 0x42,
+	0x26, 0xc7, 0x50, 0x67, 0x79, 0x3c, 0x99, 0xfb, 0xd5, 0x8e, 0xd5, 0x6d, 0x46, 0x35, 0x96, 0x0f,
+	0xe7, 0xe4, 0x01, 0x34, 0x7e, 0xcc, 0x85, 0x8c, 0x69, 0xe6, 0xd7, 0x3a, 0x56, 0x77, 0x3f, 0xb2,
+	0x95, 0x78, 0x99, 0x91, 0x33, 0x68, 0x52, 0x11, 0x27, 0xd9, 0x2d, 0x65, 0x7e, 0x5d, 0x07, 0x34,
+	0xa8, 0x18, 0x28, 0x91, 0x74, 0xc0, 0xcd, 0x50, 0xa4, 0x9c, 0x16, 0x2a, 0x7f, 0xdf, 0xd6, 0xf7,
+	0xbc, 0xae, 0x0a, 0xfe, 0xae, 0x9a, 0xc4, 0x5f, 0x15, 0xd9, 0x5b, 0x48, 0xfc, 0x29, 0xd8, 0x93,
+	0x79, 0xc1, 0xf1, 0x46, 0x67, 0x7e, 0x70, 0xfe, 0xb0, 0x57, 0x8c, 0x7b, 0xf7, 0xf0, 0xbd, 0xe1,
+	0xf5, 0x0b, 0x8e, 0x37, 0x51, 0xe9, 0xfb, 0xe6, 0x2f, 0x1b, 0x80, 0x2b, 0x54, 0xe9, 0xd3, 0x58,
+	0x33, 0xeb, 0x9a, 0xd9, 0xd9, 0xce, 0x1c, 0x69, 0x47, 0xcd, 0x05, 0xb1, 0x3c, 0x93, 0xaf, 0x00,
+	0x74, 0x65, 0x0c, 0xc1, 0xd6, 0x84, 0xf7, 0xb7, 0x13, 0x74, 0xc9, 0x34, 0xc0, 0x49, 0x16, 0xc7,
+	0xcd, 0x0a, 0x36, 0xee, 0x57, 0xf0, 0x23, 0xb0, 0xcd, 0xf7, 0x10, 0x00, 0x3b, 0xbc, 0x7a, 0x11,
+	0x7d, 0xfd, 0x8d, 0xb7, 0x47, 0x9a, 0x50, 0x0b, 0xaf, 0x86, 0xd7, 0x9e, 0x45, 0x6c, 0xa8, 0x0c,
+	0xaf, 0xbd, 0x4a, 0xf0, 0x05, 0xc0, 0x2a, 0x47, 0xe2, 0x41, 0xcb, 0xf8, 0x8e, 0x5e, 0x0e, 0x5e,
+	0x5e, 0x5e, 0x78, 0x7b, 0xa4, 0x05, 0xcd, 0xf0, 0xaa, 0x94, 0x2c, 0xc5, 0x2a, 0xcf, 0x95, 0xe0,
+	0x29, 0x38, 0xcb, 0xdc, 0xc8, 0x21, 0xb8, 0x26, 0x70, 0xf0, 0xfc, 0xfb, 0xcb, 0xd0, 0xdb, 0x23,
+	0x2e, 0x34, 0xc2, 0x2b, 0x23, 0x58, 0xc4, 0x81, 0xba, 0x39, 0x56, 0x82, 0xbe, 0x79, 0xd8, 0xe7,
+	0x38, 0xc5, 0x9d, 0x1e, 0x36, 0xe8, 0x81, 0xa7, 0x02, 0x22, 0x64, 0x38, 0xdf, 0xc5, 0xff, 0x1c,
+	0x4e, 0x94, 0xff, 0x10, 0xd9, 0x45, 0xce, 0x6e, 0xe8, 0x64, 0x97, 0x98, 0x7f, 0xab, 0xd0, 0x32,
+	0x97, 0x88, 0x22, 0x67, 0x02, 0xc9, 0x27, 0x50, 0x57, 0x46, 0xe1, 0x5b, 0x9d, 0x6a, 0xd7, 0x3d,
+	0x3f, 0x5d, 0x3c, 0xcd, 0xc2, 0xc1, 0x08, 0xc6, 0xa7, 0xfd, 0x67, 0x15, 0x6a, 0x4a, 0xfe, 0xdf,
+	0xfe, 0xfc, 0x14, 0x4e, 0x04, 0xf2, 0x19, 0xf2, 0x58, 0x20, 0xa7, 0xc9, 0x34, 0x66, 0x77, 0xb7,
+	0x63, 0xe4, 0x65, 0xaf, 0x12, 0x63, 0x1b, 0x69, 0x53, 0xa8, 0x2d, 0x84, 0x40, 0x2d, 0x45, 0x2e,
+	0x75, 0xcf, 0x3a, 0x91, 0x3e, 0x93, 0x47, 0x00, 0xa9, 0x9e, 0xe5, 0x2c, 0x4e, 0xa4, 0x6e, 0x4b,
+	0x27, 0x72, 0x4a, 0xcd, 0x40, 0x92, 0x53, 0xb0, 0x69, 0x11, 0x33, 0x94, 0xba, 0x29, 0x9d, 0xa8,
+	0x4e, 0x8b, 0x10, 0xe5, 0x6a, 0x70, 0xed, 0xed, 0x83, 0xdb, 0x78, 0xe3, 0xe0, 0x36, 0xd7, 0x07,
+	0xf7, 0x31, 0xb4, 0xa8, 0x88, 0xd3, 0x9c, 0x31, 0x4c, 0x25, 0x66, 0xbe, 0xa3, 0xcd, 0x2e, 0x15,
+	0x17, 0x0b, 0x15, 0xf9, 0x18, 0x0e, 0x97, 0xf6, 0x58, 0x50, 0x96, 0xa2, 0x0f, 0x3a, 0x97, 0x83,
+	0xa5, 0x7a, 0xa4, 0xb4, 0xea, 0x53, 0xc6, 0xbf, 0x48, 0x14, 0xb1, 0x40, 0x26, 0x7d, 0xb7, 0x63,
+	0x75, 0x6b, 0x91, 0xa3, 0x35, 0x23, 0x64, 0x92, 0x7c, 0x08, 0x07, 0xc6, 0xcc, 0x31, 0x45, 0x3a,
+	0xc3, 0xcc, 0x6f, 0x69, 0x97, 0x7d, 0xad, 0x8d, 0x4a, 0xa5, 0xa2, 0xe0, 0xcf, 0x05, 0xe5, 0x28,
+	0x54, 0x41, 0xf6, 0x4d, 0x41, 0x4a, 0xcd, 0x40, 0x6e, 0xce, 0xc9, 0xc1, 0xfd, 0x39, 0xf9, 0x12,
+	0x4e, 0x37, 0xda, 0xa5, 0x6c, 0x81, 0x0f, 0x60, 0x3f, 0x9d, 0x52, 0x64, 0x52, 0x7d, 0xef, 0x0d,
+	0x9d, 0x94, 0x2f, 0xda, 0x32, 0x4a, 0xe3, 0x7c, 0xfe, 0x5b, 0x0d, 0x5c, 0x15, 0x3e, 0x42, 0x3e,
+	0xa3, 0x29, 0x92, 0x6f, 0xa1, 0xa6, 0xf6, 0x2f, 0x39, 0x5e, 0x34, 0xcc, 0x6b, 0xdb, 0xb8, 0xed,
+	0x6d, 0x76, 0x51, 0x70, 0xf6, 0xeb, 0x5f, 0xff, 0xfc, 0x5e, 0x39, 0x26, 0x47, 0x7a, 0xa5, 0xcf,
+	0x3e, 0xeb, 0xab, 0x76, 0xe9, 0x4f, 0x15, 0xe1, 0x07, 0xb0, 0xcd, 0xd6, 0x26, 0xcb, 0xe6, 0x5b,
+	0xdb, 0xe2, 0x5b, 0x68, 0xef, 0x69, 0x9a, 0x1f, 0x1c, 0xaf, 0xd1, 0x4c, 0x77, 0x3c, 0xb3, 0x9e,
+	0x28, 0xa4, 0x59, 0x2d, 0x2b, 0xe4, 0xda, 0xaa, 0xd9, 0x19, 0x79, 0xa7, 0xa3, 0x4a, 0xa4, 0x99,
+	0xe4, 0x15, 0x72, 0x6d, 0xb2, 0x77, 0x46, 0x66, 0x3a, 0x4a, 0x21, 0x43, 0xa8, 0xeb, 0x59, 0x27,
+	0x27, 0xab, 0xd0, 0xd5, 0xe8, 0x6f, 0x01, 0x3e, 0xd2, 0xc0, 0x07, 0x01, 0x59, 0x03, 0x72, 0x15,
+	0xa4, 0x78, 0x29, 0x38, 0xcb, 0xc7, 0x25, 0xfe, 0x22, 0x7a, 0x73, 0x3d, 0xb4, 0xcf, 0xb6, 0x58,
+	0xca, 0x0b, 0x1e, 0xeb, 0x0b, 0xde, 0x0d, 0xde, 0x59, 0xbb, 0x60, 0x82, 0xcc, 0x34, 0xc6, 0x33,
+	0xeb, 0xc9, 0xd8, 0xd6, 0xbf, 0xe0, 0xcf, 0xff, 0x0b, 0x00, 0x00, 0xff, 0xff, 0xd7, 0xfc, 0x4a,
+	0x18, 0xb2, 0x07, 0x00, 0x00,
 }
 
 // Reference imports to suppress errors if they are not otherwise used.
@@ -735,6 +811,29 @@ type UserServiceServer interface {
 	GenConfig(context.Context, *UserGenConfigRequest) (*UserGenConfigResponse, error)
 }
 
+// UnimplementedUserServiceServer can be embedded to have forward compatible implementations.
+type UnimplementedUserServiceServer struct {
+}
+
+func (*UnimplementedUserServiceServer) List(ctx context.Context, req *UserListRequest) (*UserResponse, error) {
+	return nil, status.Errorf(codes.Unimplemented, "method List not implemented")
+}
+func (*UnimplementedUserServiceServer) Create(ctx context.Context, req *UserCreateRequest) (*UserResponse, error) {
+	return nil, status.Errorf(codes.Unimplemented, "method Create not implemented")
+}
+func (*UnimplementedUserServiceServer) Update(ctx context.Context, req *UserUpdateRequest) (*UserResponse, error) {
+	return nil, status.Errorf(codes.Unimplemented, "method Update not implemented")
+}
+func (*UnimplementedUserServiceServer) Delete(ctx context.Context, req *UserDeleteRequest) (*UserResponse, error) {
+	return nil, status.Errorf(codes.Unimplemented, "method Delete not implemented")
+}
+func (*UnimplementedUserServiceServer) Renew(ctx context.Context, req *UserRenewRequest) (*UserResponse, error) {
+	return nil, status.Errorf(codes.Unimplemented, "method Renew not implemented")
+}
+func (*UnimplementedUserServiceServer) GenConfig(ctx context.Context, req *UserGenConfigRequest) (*UserGenConfigResponse, error) {
+	return nil, status.Errorf(codes.Unimplemented, "method GenConfig not implemented")
+}
+
 func RegisterUserServiceServer(s *grpc.Server, srv UserServiceServer) {
 	s.RegisterService(&_UserService_serviceDesc, srv)
 }
@@ -879,62 +978,3 @@ var _UserService_serviceDesc = grpc.ServiceDesc{
 	Streams:  []grpc.StreamDesc{},
 	Metadata: "user.proto",
 }
-
-func init() { proto.RegisterFile("user.proto", fileDescriptor_user_32c669a016e64e35) }
-
-var fileDescriptor_user_32c669a016e64e35 = []byte{
-	// 845 bytes of a gzipped FileDescriptorProto
-	0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0xac, 0x55, 0xcf, 0x6e, 0xf3, 0x44,
-	0x10, 0x27, 0x89, 0xe3, 0xc4, 0xe3, 0x24, 0x4d, 0x37, 0x2d, 0x75, 0x43, 0x0b, 0xad, 0x11, 0x50,
-	0x81, 0x94, 0x40, 0xe8, 0x01, 0x21, 0x84, 0x14, 0xa5, 0x10, 0x2a, 0x81, 0x53, 0x9c, 0x56, 0x3d,
-	0x5a, 0x8e, 0xbd, 0x0d, 0x2b, 0xa5, 0x6b, 0xe3, 0x75, 0x12, 0xb8, 0x22, 0xf1, 0x04, 0xbc, 0x0b,
-	0x07, 0x5e, 0x83, 0x03, 0x2f, 0xc0, 0x43, 0x7c, 0xc7, 0x6f, 0xff, 0x38, 0x49, 0x93, 0xa6, 0x9f,
-	0x72, 0xf8, 0x4e, 0xde, 0x99, 0xf9, 0xcd, 0x6f, 0x66, 0x67, 0x67, 0xc6, 0x00, 0x53, 0x86, 0x93,
-	0x56, 0x9c, 0x44, 0x69, 0x84, 0xf2, 0xf1, 0xa8, 0x79, 0x32, 0x8e, 0xa2, 0xf1, 0x04, 0xb7, 0xfd,
-	0x98, 0xb4, 0x7d, 0x4a, 0xa3, 0xd4, 0x4f, 0x49, 0x44, 0x99, 0x42, 0xd8, 0xfb, 0xb0, 0x77, 0xc7,
-	0xf1, 0x3f, 0x12, 0x96, 0xba, 0xf8, 0xd7, 0x29, 0x66, 0xa9, 0xfd, 0x77, 0x0e, 0xf6, 0x85, 0xae,
-	0x97, 0x60, 0x3f, 0xc5, 0x99, 0x16, 0x35, 0xa1, 0x2c, 0x88, 0xa9, 0xff, 0x88, 0xad, 0xdc, 0x59,
-	0xee, 0xc2, 0x70, 0x97, 0xb2, 0xb0, 0xc5, 0x3e, 0x63, 0xf3, 0x28, 0x09, 0xad, 0xbc, 0xb2, 0x2d,
-	0x64, 0xd4, 0x80, 0x22, 0x8d, 0xbc, 0xf1, 0xdc, 0x2a, 0x70, 0x43, 0xd9, 0xd5, 0x68, 0xd4, 0x9f,
-	0xa3, 0x23, 0x28, 0xfd, 0x12, 0xb1, 0xd4, 0x23, 0xa1, 0xa5, 0x71, 0x75, 0xd5, 0xd5, 0x85, 0x78,
-	0x1d, 0xa2, 0x63, 0x28, 0x13, 0xe6, 0xf9, 0xe1, 0x23, 0xa1, 0x56, 0x51, 0x3a, 0x94, 0x08, 0xeb,
-	0x0a, 0x11, 0x9d, 0x81, 0x19, 0x62, 0x16, 0x24, 0x24, 0x16, 0xf9, 0x5b, 0xba, 0x8c, 0xf3, 0x54,
-	0x65, 0xff, 0x57, 0x50, 0x89, 0xdf, 0xc5, 0xe1, 0x5b, 0x48, 0xfc, 0x12, 0xf4, 0xf1, 0x3c, 0x4e,
-	0xf0, 0x83, 0xcc, 0xbc, 0xd6, 0x39, 0x69, 0xc5, 0xa3, 0xd6, 0x33, 0xfa, 0x56, 0xff, 0xfe, 0x86,
-	0x63, 0xdc, 0x0c, 0xfb, 0xf2, 0xcd, 0xba, 0x60, 0x32, 0x51, 0xfa, 0xc0, 0x93, 0x9c, 0x45, 0xc9,
-	0x79, 0xb6, 0x9d, 0x73, 0x28, 0x81, 0x92, 0x17, 0xd8, 0xf2, 0x8c, 0xbe, 0x05, 0x90, 0x95, 0x51,
-	0x0c, 0xba, 0x64, 0xf8, 0x60, 0x3b, 0x83, 0x2c, 0x99, 0x24, 0x30, 0xfc, 0xc5, 0x71, 0xb3, 0x82,
-	0xa5, 0xe7, 0x15, 0xfc, 0x18, 0x74, 0x75, 0x1f, 0x04, 0xa0, 0x3b, 0x83, 0x1b, 0xf7, 0xbb, 0xef,
-	0xeb, 0xef, 0xa0, 0x32, 0x68, 0xce, 0xa0, 0x7f, 0x5f, 0xcf, 0x21, 0x1d, 0xf2, 0xfc, 0x9b, 0xb7,
-	0xbf, 0x02, 0x58, 0xe5, 0x88, 0xea, 0x50, 0x51, 0xd8, 0xe1, 0x6d, 0xf7, 0xf6, 0xba, 0xc7, 0x3d,
-	0x2a, 0x50, 0x76, 0x06, 0x99, 0x94, 0x13, 0x5c, 0xd9, 0x39, 0x6f, 0x5f, 0x82, 0xb1, 0xcc, 0x0d,
-	0xed, 0x81, 0xa9, 0x1c, 0xbb, 0x57, 0x3f, 0x5d, 0x3b, 0xdc, 0xcf, 0x84, 0x92, 0x33, 0x50, 0x42,
-	0x0e, 0x19, 0x50, 0x54, 0xc7, 0xbc, 0xdd, 0x56, 0x0f, 0x7b, 0x85, 0x27, 0x78, 0xa7, 0x87, 0xb5,
-	0x5b, 0x50, 0x17, 0x0e, 0x2e, 0xa6, 0x78, 0xbe, 0x0b, 0xbe, 0x03, 0x07, 0x02, 0xdf, 0xc7, 0xb4,
-	0x17, 0xd1, 0x07, 0x32, 0xde, 0xc5, 0xe7, 0x55, 0x01, 0x2a, 0x2a, 0x08, 0x8b, 0xf9, 0x40, 0x61,
-	0xf4, 0x19, 0x14, 0x85, 0x91, 0x71, 0x64, 0xe1, 0xc2, 0xec, 0x1c, 0x2e, 0x9e, 0x66, 0x01, 0x50,
-	0x82, 0xc2, 0x34, 0xff, 0x29, 0x80, 0x26, 0xe4, 0x37, 0xf6, 0xe7, 0xe7, 0x70, 0xc0, 0x8f, 0x33,
-	0x9c, 0x78, 0xfc, 0x43, 0xfc, 0x89, 0x47, 0xa7, 0x8f, 0x23, 0x9c, 0x64, 0xbd, 0x8a, 0x94, 0x6d,
-	0x28, 0x4d, 0x8e, 0xb4, 0x20, 0x04, 0x5a, 0x80, 0x93, 0x54, 0xf6, 0xac, 0xe1, 0xca, 0x33, 0x3a,
-	0x05, 0x08, 0xe4, 0x2c, 0x87, 0x9e, 0x9f, 0xca, 0xb6, 0x34, 0x5c, 0x23, 0xd3, 0x74, 0x53, 0x74,
-	0x08, 0x3a, 0x89, 0x3d, 0x8a, 0x53, 0xd9, 0x94, 0x86, 0x5b, 0x24, 0xb1, 0x83, 0xd3, 0xd5, 0xe0,
-	0xea, 0xdb, 0x07, 0xb7, 0xf4, 0xe2, 0xe0, 0x96, 0xd7, 0x07, 0xf7, 0x1c, 0x2a, 0xdc, 0x14, 0x44,
-	0x94, 0xe2, 0x80, 0x47, 0xb4, 0x0c, 0x69, 0x36, 0x09, 0xeb, 0x2d, 0x54, 0xe8, 0x13, 0xd8, 0x5b,
-	0xda, 0x3d, 0x46, 0x68, 0x80, 0x2d, 0x90, 0xb9, 0xd4, 0x96, 0xea, 0xa1, 0xd0, 0x8a, 0xab, 0x8c,
-	0x7e, 0x4f, 0x31, 0xe3, 0xf5, 0xa0, 0xa9, 0x65, 0x72, 0x8c, 0xe6, 0x1a, 0x52, 0x33, 0xe4, 0x0a,
-	0xf4, 0x11, 0xd4, 0x94, 0x39, 0xc1, 0x01, 0x26, 0x33, 0x1e, 0xac, 0x22, 0x21, 0x55, 0xa9, 0x75,
-	0x33, 0xa5, 0x60, 0xc1, 0xbf, 0xc5, 0x24, 0xe1, 0x40, 0x5e, 0x90, 0xaa, 0x2a, 0x48, 0xa6, 0xe1,
-	0x05, 0xd9, 0x98, 0x93, 0xda, 0xf3, 0x39, 0xf9, 0x06, 0x0e, 0x37, 0xda, 0x25, 0x6b, 0x81, 0x0f,
-	0xa1, 0x1a, 0x4c, 0x08, 0x4f, 0x45, 0xdc, 0x97, 0x1b, 0xb2, 0x17, 0xad, 0x28, 0xa5, 0x02, 0x77,
-	0xfe, 0xd4, 0xc0, 0x14, 0xee, 0xfc, 0xe1, 0x66, 0x84, 0x5f, 0xea, 0x07, 0xd0, 0xc4, 0xfe, 0x45,
-	0x8d, 0x45, 0xc3, 0x3c, 0xd9, 0xc6, 0xcd, 0xfa, 0x66, 0x17, 0xd9, 0xc7, 0x7f, 0xfc, 0xfb, 0xff,
-	0x5f, 0xf9, 0x06, 0xda, 0x97, 0x2b, 0x7d, 0xf6, 0x45, 0x5b, 0xb4, 0x4b, 0x7b, 0x22, 0x18, 0x7e,
-	0x06, 0x5d, 0x6d, 0x6d, 0xb4, 0x6c, 0xbe, 0xb5, 0x2d, 0xbe, 0x85, 0xed, 0x7d, 0xc9, 0x66, 0xd9,
-	0x8d, 0x35, 0x36, 0xd5, 0x1d, 0x5f, 0xe7, 0x3e, 0x15, 0x94, 0x6a, 0xb5, 0xac, 0x28, 0xd7, 0x56,
-	0xcd, 0xce, 0x94, 0x53, 0xe9, 0x95, 0x51, 0xaa, 0x49, 0x5e, 0x51, 0xae, 0x4d, 0xf6, 0xce, 0x94,
-	0xa1, 0xf4, 0x12, 0x94, 0x0e, 0x14, 0xe5, 0xac, 0xa3, 0x83, 0x95, 0xeb, 0x6a, 0xf4, 0xb7, 0x10,
-	0x9e, 0x4a, 0xc2, 0x23, 0x1b, 0xad, 0x11, 0x26, 0xc2, 0x49, 0xf0, 0x05, 0x60, 0x2c, 0x1f, 0x17,
-	0x59, 0x0b, 0xef, 0xcd, 0xf5, 0xd0, 0x3c, 0xde, 0x62, 0xc9, 0x02, 0x9c, 0xcb, 0x00, 0xef, 0xd9,
-	0xef, 0xae, 0x05, 0x18, 0x63, 0xaa, 0x1a, 0x83, 0x07, 0x19, 0xe9, 0xf2, 0x17, 0xfc, 0xe5, 0xeb,
-	0x00, 0x00, 0x00, 0xff, 0xff, 0xd7, 0xfc, 0x4a, 0x18, 0xb2, 0x07, 0x00, 0x00,
-}

+ 107 - 78
api/pb/vpn.pb.go

@@ -3,14 +3,15 @@
 
 package pb
 
-import proto "github.com/golang/protobuf/proto"
-import fmt "fmt"
-import math "math"
-import _ "google.golang.org/genproto/googleapis/api/annotations"
-
 import (
-	context "golang.org/x/net/context"
+	context "context"
+	fmt "fmt"
+	proto "github.com/golang/protobuf/proto"
+	_ "google.golang.org/genproto/googleapis/api/annotations"
 	grpc "google.golang.org/grpc"
+	codes "google.golang.org/grpc/codes"
+	status "google.golang.org/grpc/status"
+	math "math"
 )
 
 // Reference imports to suppress errors if they are not otherwise used.
@@ -22,7 +23,7 @@ var _ = math.Inf
 // is compatible with the proto package it is being compiled against.
 // A compilation error at this line likely means your copy of the
 // proto package needs to be updated.
-const _ = proto.ProtoPackageIsVersion2 // please upgrade the proto package
+const _ = proto.ProtoPackageIsVersion3 // please upgrade the proto package
 
 type VPNProto int32
 
@@ -37,6 +38,7 @@ var VPNProto_name = map[int32]string{
 	1: "UDP",
 	2: "TCP",
 }
+
 var VPNProto_value = map[string]int32{
 	"NOPREF": 0,
 	"UDP":    1,
@@ -46,8 +48,9 @@ var VPNProto_value = map[string]int32{
 func (x VPNProto) String() string {
 	return proto.EnumName(VPNProto_name, int32(x))
 }
+
 func (VPNProto) EnumDescriptor() ([]byte, []int) {
-	return fileDescriptor_vpn_38c1de627905a14e, []int{0}
+	return fileDescriptor_75c5922f473942e1, []int{0}
 }
 
 type VPNStatusRequest struct {
@@ -60,16 +63,17 @@ func (m *VPNStatusRequest) Reset()         { *m = VPNStatusRequest{} }
 func (m *VPNStatusRequest) String() string { return proto.CompactTextString(m) }
 func (*VPNStatusRequest) ProtoMessage()    {}
 func (*VPNStatusRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_vpn_38c1de627905a14e, []int{0}
+	return fileDescriptor_75c5922f473942e1, []int{0}
 }
+
 func (m *VPNStatusRequest) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_VPNStatusRequest.Unmarshal(m, b)
 }
 func (m *VPNStatusRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_VPNStatusRequest.Marshal(b, m, deterministic)
 }
-func (dst *VPNStatusRequest) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_VPNStatusRequest.Merge(dst, src)
+func (m *VPNStatusRequest) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_VPNStatusRequest.Merge(m, src)
 }
 func (m *VPNStatusRequest) XXX_Size() int {
 	return xxx_messageInfo_VPNStatusRequest.Size(m)
@@ -98,16 +102,17 @@ func (m *VPNInitRequest) Reset()         { *m = VPNInitRequest{} }
 func (m *VPNInitRequest) String() string { return proto.CompactTextString(m) }
 func (*VPNInitRequest) ProtoMessage()    {}
 func (*VPNInitRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_vpn_38c1de627905a14e, []int{1}
+	return fileDescriptor_75c5922f473942e1, []int{1}
 }
+
 func (m *VPNInitRequest) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_VPNInitRequest.Unmarshal(m, b)
 }
 func (m *VPNInitRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_VPNInitRequest.Marshal(b, m, deterministic)
 }
-func (dst *VPNInitRequest) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_VPNInitRequest.Merge(dst, src)
+func (m *VPNInitRequest) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_VPNInitRequest.Merge(m, src)
 }
 func (m *VPNInitRequest) XXX_Size() int {
 	return xxx_messageInfo_VPNInitRequest.Size(m)
@@ -186,16 +191,17 @@ func (m *VPNUpdateRequest) Reset()         { *m = VPNUpdateRequest{} }
 func (m *VPNUpdateRequest) String() string { return proto.CompactTextString(m) }
 func (*VPNUpdateRequest) ProtoMessage()    {}
 func (*VPNUpdateRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_vpn_38c1de627905a14e, []int{2}
+	return fileDescriptor_75c5922f473942e1, []int{2}
 }
+
 func (m *VPNUpdateRequest) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_VPNUpdateRequest.Unmarshal(m, b)
 }
 func (m *VPNUpdateRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_VPNUpdateRequest.Marshal(b, m, deterministic)
 }
-func (dst *VPNUpdateRequest) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_VPNUpdateRequest.Merge(dst, src)
+func (m *VPNUpdateRequest) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_VPNUpdateRequest.Merge(m, src)
 }
 func (m *VPNUpdateRequest) XXX_Size() int {
 	return xxx_messageInfo_VPNUpdateRequest.Size(m)
@@ -230,16 +236,17 @@ func (m *VPNRestartRequest) Reset()         { *m = VPNRestartRequest{} }
 func (m *VPNRestartRequest) String() string { return proto.CompactTextString(m) }
 func (*VPNRestartRequest) ProtoMessage()    {}
 func (*VPNRestartRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_vpn_38c1de627905a14e, []int{3}
+	return fileDescriptor_75c5922f473942e1, []int{3}
 }
+
 func (m *VPNRestartRequest) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_VPNRestartRequest.Unmarshal(m, b)
 }
 func (m *VPNRestartRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_VPNRestartRequest.Marshal(b, m, deterministic)
 }
-func (dst *VPNRestartRequest) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_VPNRestartRequest.Merge(dst, src)
+func (m *VPNRestartRequest) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_VPNRestartRequest.Merge(m, src)
 }
 func (m *VPNRestartRequest) XXX_Size() int {
 	return xxx_messageInfo_VPNRestartRequest.Size(m)
@@ -273,16 +280,17 @@ func (m *VPNStatusResponse) Reset()         { *m = VPNStatusResponse{} }
 func (m *VPNStatusResponse) String() string { return proto.CompactTextString(m) }
 func (*VPNStatusResponse) ProtoMessage()    {}
 func (*VPNStatusResponse) Descriptor() ([]byte, []int) {
-	return fileDescriptor_vpn_38c1de627905a14e, []int{4}
+	return fileDescriptor_75c5922f473942e1, []int{4}
 }
+
 func (m *VPNStatusResponse) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_VPNStatusResponse.Unmarshal(m, b)
 }
 func (m *VPNStatusResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_VPNStatusResponse.Marshal(b, m, deterministic)
 }
-func (dst *VPNStatusResponse) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_VPNStatusResponse.Merge(dst, src)
+func (m *VPNStatusResponse) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_VPNStatusResponse.Merge(m, src)
 }
 func (m *VPNStatusResponse) XXX_Size() int {
 	return xxx_messageInfo_VPNStatusResponse.Size(m)
@@ -394,16 +402,17 @@ func (m *VPNInitResponse) Reset()         { *m = VPNInitResponse{} }
 func (m *VPNInitResponse) String() string { return proto.CompactTextString(m) }
 func (*VPNInitResponse) ProtoMessage()    {}
 func (*VPNInitResponse) Descriptor() ([]byte, []int) {
-	return fileDescriptor_vpn_38c1de627905a14e, []int{5}
+	return fileDescriptor_75c5922f473942e1, []int{5}
 }
+
 func (m *VPNInitResponse) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_VPNInitResponse.Unmarshal(m, b)
 }
 func (m *VPNInitResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_VPNInitResponse.Marshal(b, m, deterministic)
 }
-func (dst *VPNInitResponse) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_VPNInitResponse.Merge(dst, src)
+func (m *VPNInitResponse) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_VPNInitResponse.Merge(m, src)
 }
 func (m *VPNInitResponse) XXX_Size() int {
 	return xxx_messageInfo_VPNInitResponse.Size(m)
@@ -424,16 +433,17 @@ func (m *VPNUpdateResponse) Reset()         { *m = VPNUpdateResponse{} }
 func (m *VPNUpdateResponse) String() string { return proto.CompactTextString(m) }
 func (*VPNUpdateResponse) ProtoMessage()    {}
 func (*VPNUpdateResponse) Descriptor() ([]byte, []int) {
-	return fileDescriptor_vpn_38c1de627905a14e, []int{6}
+	return fileDescriptor_75c5922f473942e1, []int{6}
 }
+
 func (m *VPNUpdateResponse) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_VPNUpdateResponse.Unmarshal(m, b)
 }
 func (m *VPNUpdateResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_VPNUpdateResponse.Marshal(b, m, deterministic)
 }
-func (dst *VPNUpdateResponse) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_VPNUpdateResponse.Merge(dst, src)
+func (m *VPNUpdateResponse) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_VPNUpdateResponse.Merge(m, src)
 }
 func (m *VPNUpdateResponse) XXX_Size() int {
 	return xxx_messageInfo_VPNUpdateResponse.Size(m)
@@ -454,16 +464,17 @@ func (m *VPNRestartResponse) Reset()         { *m = VPNRestartResponse{} }
 func (m *VPNRestartResponse) String() string { return proto.CompactTextString(m) }
 func (*VPNRestartResponse) ProtoMessage()    {}
 func (*VPNRestartResponse) Descriptor() ([]byte, []int) {
-	return fileDescriptor_vpn_38c1de627905a14e, []int{7}
+	return fileDescriptor_75c5922f473942e1, []int{7}
 }
+
 func (m *VPNRestartResponse) XXX_Unmarshal(b []byte) error {
 	return xxx_messageInfo_VPNRestartResponse.Unmarshal(m, b)
 }
 func (m *VPNRestartResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
 	return xxx_messageInfo_VPNRestartResponse.Marshal(b, m, deterministic)
 }
-func (dst *VPNRestartResponse) XXX_Merge(src proto.Message) {
-	xxx_messageInfo_VPNRestartResponse.Merge(dst, src)
+func (m *VPNRestartResponse) XXX_Merge(src proto.Message) {
+	xxx_messageInfo_VPNRestartResponse.Merge(m, src)
 }
 func (m *VPNRestartResponse) XXX_Size() int {
 	return xxx_messageInfo_VPNRestartResponse.Size(m)
@@ -475,6 +486,7 @@ func (m *VPNRestartResponse) XXX_DiscardUnknown() {
 var xxx_messageInfo_VPNRestartResponse proto.InternalMessageInfo
 
 func init() {
+	proto.RegisterEnum("pb.VPNProto", VPNProto_name, VPNProto_value)
 	proto.RegisterType((*VPNStatusRequest)(nil), "pb.VPNStatusRequest")
 	proto.RegisterType((*VPNInitRequest)(nil), "pb.VPNInitRequest")
 	proto.RegisterType((*VPNUpdateRequest)(nil), "pb.VPNUpdateRequest")
@@ -483,7 +495,52 @@ func init() {
 	proto.RegisterType((*VPNInitResponse)(nil), "pb.VPNInitResponse")
 	proto.RegisterType((*VPNUpdateResponse)(nil), "pb.VPNUpdateResponse")
 	proto.RegisterType((*VPNRestartResponse)(nil), "pb.VPNRestartResponse")
-	proto.RegisterEnum("pb.VPNProto", VPNProto_name, VPNProto_value)
+}
+
+func init() { proto.RegisterFile("vpn.proto", fileDescriptor_75c5922f473942e1) }
+
+var fileDescriptor_75c5922f473942e1 = []byte{
+	// 628 bytes of a gzipped FileDescriptorProto
+	0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x74, 0x93, 0x4f, 0x6f, 0xd3, 0x4c,
+	0x10, 0xc6, 0x5f, 0x3b, 0xa9, 0x93, 0x4c, 0xff, 0xb9, 0xd3, 0xf4, 0xad, 0x09, 0x54, 0xaa, 0xcc,
+	0x25, 0xb4, 0x52, 0x23, 0xca, 0x8d, 0x0b, 0x2a, 0xa5, 0x48, 0x48, 0x55, 0x30, 0xa6, 0xcd, 0xd5,
+	0xda, 0x38, 0xdb, 0x62, 0x35, 0xf1, 0x2e, 0xbb, 0xeb, 0x08, 0xf5, 0xc8, 0x95, 0x23, 0x1f, 0x8d,
+	0x13, 0x9c, 0xf9, 0x20, 0xc8, 0x63, 0x3b, 0x75, 0x22, 0xb8, 0x8d, 0x7f, 0x33, 0x79, 0x34, 0x79,
+	0x9e, 0x59, 0xe8, 0xcc, 0x65, 0x7a, 0x22, 0x95, 0x30, 0x02, 0x6d, 0x39, 0xee, 0x3d, 0xb9, 0x15,
+	0xe2, 0x76, 0xca, 0x07, 0x4c, 0x26, 0x03, 0x96, 0xa6, 0xc2, 0x30, 0x93, 0x88, 0x54, 0x17, 0x13,
+	0x3e, 0x82, 0x3b, 0x0a, 0x86, 0x1f, 0x0d, 0x33, 0x99, 0x0e, 0xf9, 0xe7, 0x8c, 0x6b, 0xe3, 0x7f,
+	0xb3, 0x61, 0x6b, 0x14, 0x0c, 0xdf, 0xa5, 0x89, 0x29, 0x11, 0xf6, 0xa0, 0xfd, 0x49, 0x68, 0x93,
+	0xb2, 0x19, 0xf7, 0xac, 0x43, 0xab, 0xdf, 0x09, 0x17, 0xdf, 0x88, 0xd0, 0x94, 0x42, 0x19, 0xcf,
+	0x26, 0x4e, 0x35, 0x1e, 0x03, 0x90, 0x7e, 0x24, 0x15, 0xbf, 0xf1, 0x1a, 0x87, 0x56, 0x7f, 0xeb,
+	0x74, 0xe3, 0x44, 0x8e, 0x4f, 0x46, 0xc1, 0x30, 0xc8, 0x1b, 0x61, 0x87, 0xfa, 0x81, 0xe2, 0x37,
+	0xf8, 0x08, 0xda, 0x89, 0x8c, 0xc6, 0x53, 0x11, 0xdf, 0x79, 0x4d, 0x12, 0x69, 0x25, 0xf2, 0x75,
+	0xfe, 0x89, 0x2e, 0x34, 0x26, 0xa9, 0xf6, 0xd6, 0x88, 0xe6, 0x25, 0x3e, 0x03, 0xf7, 0x8e, 0x73,
+	0xc9, 0xa6, 0xc9, 0x9c, 0x47, 0x92, 0xab, 0x44, 0x4c, 0x3c, 0x87, 0xda, 0xdb, 0x0b, 0x1e, 0x10,
+	0xc6, 0x63, 0xd8, 0x79, 0x18, 0x35, 0xc9, 0x8c, 0x8b, 0xcc, 0x78, 0x2d, 0x9a, 0x7d, 0xd0, 0xb8,
+	0x2a, 0x38, 0xee, 0x43, 0x2b, 0xd3, 0x3c, 0x9a, 0xde, 0x0b, 0xaf, 0x7d, 0x68, 0xf5, 0xdb, 0xa1,
+	0x93, 0x69, 0x7e, 0x79, 0x2f, 0xfc, 0x57, 0xe4, 0xd0, 0xb5, 0x9c, 0x30, 0xc3, 0x2b, 0x3b, 0xea,
+	0x1b, 0x5b, 0x7f, 0xdd, 0xd8, 0x5e, 0x6c, 0xec, 0xef, 0xc2, 0xce, 0x28, 0x18, 0x86, 0x5c, 0x1b,
+	0xa6, 0x2a, 0x43, 0xfd, 0x9f, 0x36, 0xd1, 0xca, 0x78, 0x2d, 0x45, 0xaa, 0xc9, 0xca, 0x9a, 0xc5,
+	0x54, 0xe3, 0x53, 0xd8, 0xd4, 0x5c, 0x25, 0x6c, 0x1a, 0xa5, 0xd9, 0x6c, 0xcc, 0x55, 0x29, 0xbd,
+	0x51, 0xc0, 0x21, 0xb1, 0xa5, 0x7c, 0x1a, 0xff, 0xc8, 0xa7, 0x59, 0xcb, 0x07, 0xa1, 0x19, 0x73,
+	0x65, 0x4a, 0x63, 0xa9, 0xce, 0x1d, 0x88, 0x59, 0x44, 0xb8, 0x30, 0xd4, 0x89, 0xd9, 0x79, 0xde,
+	0x70, 0xa1, 0x91, 0xf2, 0xca, 0xb9, 0xbc, 0xcc, 0x7f, 0x3e, 0x63, 0xfa, 0x8e, 0x9c, 0xea, 0x84,
+	0x54, 0xe3, 0x01, 0x40, 0xac, 0x38, 0x33, 0x7c, 0x12, 0x31, 0xe3, 0x75, 0xa8, 0xd3, 0x29, 0xc9,
+	0x99, 0xc1, 0x2e, 0xac, 0x51, 0xe2, 0x1e, 0x50, 0xa7, 0xf8, 0xa8, 0xdc, 0x5a, 0x7f, 0xc8, 0xf7,
+	0x00, 0x80, 0x7f, 0x91, 0x89, 0xe2, 0x3a, 0x97, 0xd9, 0x28, 0x64, 0x4a, 0x72, 0x66, 0xd0, 0x87,
+	0xcd, 0x98, 0x45, 0xb5, 0x89, 0x4d, 0x9a, 0x58, 0x8f, 0xd9, 0x45, 0x35, 0xe3, 0xef, 0xc0, 0xf6,
+	0xe2, 0x7c, 0x0b, 0x63, 0xcb, 0x0c, 0xaa, 0x10, 0x4b, 0xd8, 0x05, 0xac, 0x07, 0x53, 0xd0, 0xa3,
+	0x3e, 0xb4, 0xab, 0x23, 0x45, 0x00, 0x67, 0xf8, 0x3e, 0x08, 0x2f, 0xde, 0xba, 0xff, 0x61, 0x0b,
+	0x1a, 0xd7, 0x6f, 0x02, 0xd7, 0xca, 0x8b, 0xab, 0xf3, 0xc0, 0xb5, 0x4f, 0x7f, 0xd9, 0x00, 0x79,
+	0x86, 0x5c, 0xcd, 0x93, 0x98, 0xe3, 0x07, 0x70, 0x8a, 0x38, 0xb1, 0x5b, 0x5e, 0xfa, 0xd2, 0xb3,
+	0xea, 0xed, 0xad, 0xd0, 0x72, 0x8b, 0xde, 0xd7, 0x1f, 0xbf, 0xbf, 0xdb, 0x5d, 0x44, 0x7a, 0xa1,
+	0xf3, 0xe7, 0x83, 0xb9, 0x4c, 0x07, 0xba, 0x10, 0xba, 0x84, 0x66, 0xfe, 0x37, 0x10, 0xcb, 0x9f,
+	0xd6, 0x9e, 0x64, 0x6f, 0x77, 0x89, 0x95, 0x62, 0x8f, 0x49, 0x6c, 0xcf, 0x77, 0xeb, 0x62, 0x49,
+	0x9a, 0x98, 0x97, 0xd6, 0x11, 0x5e, 0x81, 0x53, 0x38, 0xb0, 0x58, 0x70, 0xe9, 0xaa, 0x17, 0x0b,
+	0xae, 0xd8, 0x74, 0x40, 0x9a, 0xfb, 0xfe, 0xd2, 0x82, 0x19, 0xcd, 0xe4, 0xaa, 0xd7, 0xd0, 0x2a,
+	0x2d, 0xc4, 0x4a, 0x60, 0xf9, 0xd6, 0x7b, 0xff, 0xaf, 0xe2, 0x95, 0x65, 0x77, 0xeb, 0xc2, 0xaa,
+	0x18, 0x1a, 0x3b, 0x74, 0x20, 0x2f, 0xfe, 0x04, 0x00, 0x00, 0xff, 0xff, 0xba, 0x04, 0x57, 0xbd,
+	0xce, 0x04, 0x00, 0x00,
 }
 
 // Reference imports to suppress errors if they are not otherwise used.
@@ -556,6 +613,23 @@ type VPNServiceServer interface {
 	Restart(context.Context, *VPNRestartRequest) (*VPNRestartResponse, error)
 }
 
+// UnimplementedVPNServiceServer can be embedded to have forward compatible implementations.
+type UnimplementedVPNServiceServer struct {
+}
+
+func (*UnimplementedVPNServiceServer) Status(ctx context.Context, req *VPNStatusRequest) (*VPNStatusResponse, error) {
+	return nil, status.Errorf(codes.Unimplemented, "method Status not implemented")
+}
+func (*UnimplementedVPNServiceServer) Init(ctx context.Context, req *VPNInitRequest) (*VPNInitResponse, error) {
+	return nil, status.Errorf(codes.Unimplemented, "method Init not implemented")
+}
+func (*UnimplementedVPNServiceServer) Update(ctx context.Context, req *VPNUpdateRequest) (*VPNUpdateResponse, error) {
+	return nil, status.Errorf(codes.Unimplemented, "method Update not implemented")
+}
+func (*UnimplementedVPNServiceServer) Restart(ctx context.Context, req *VPNRestartRequest) (*VPNRestartResponse, error) {
+	return nil, status.Errorf(codes.Unimplemented, "method Restart not implemented")
+}
+
 func RegisterVPNServiceServer(s *grpc.Server, srv VPNServiceServer) {
 	s.RegisterService(&_VPNService_serviceDesc, srv)
 }
@@ -656,48 +730,3 @@ var _VPNService_serviceDesc = grpc.ServiceDesc{
 	Streams:  []grpc.StreamDesc{},
 	Metadata: "vpn.proto",
 }
-
-func init() { proto.RegisterFile("vpn.proto", fileDescriptor_vpn_38c1de627905a14e) }
-
-var fileDescriptor_vpn_38c1de627905a14e = []byte{
-	// 619 bytes of a gzipped FileDescriptorProto
-	0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0x74, 0x93, 0xcf, 0x6e, 0xd3, 0x40,
-	0x10, 0xc6, 0x89, 0x93, 0x3a, 0xc9, 0xf4, 0x9f, 0x3b, 0x4d, 0xa9, 0x09, 0x54, 0x42, 0xe6, 0x52,
-	0x8a, 0xd4, 0x88, 0x72, 0xe3, 0x82, 0xa0, 0x14, 0x09, 0xa9, 0x2a, 0x26, 0xb4, 0x5c, 0xad, 0x8d,
-	0xb3, 0x14, 0xab, 0x89, 0x77, 0xb1, 0x37, 0x11, 0xea, 0x91, 0x2b, 0x47, 0x1e, 0x8d, 0x13, 0x9c,
-	0x79, 0x10, 0x76, 0x67, 0xed, 0xc4, 0x8e, 0xe0, 0x36, 0xfb, 0x9b, 0xd9, 0x4f, 0xb3, 0xdf, 0xcc,
-	0x42, 0x77, 0x2e, 0xd3, 0x63, 0x99, 0x09, 0x25, 0xd0, 0x91, 0xa3, 0xfe, 0x83, 0x6b, 0x21, 0xae,
-	0x27, 0x7c, 0xc0, 0x64, 0x32, 0x60, 0x69, 0x2a, 0x14, 0x53, 0x89, 0x48, 0x73, 0x5b, 0x11, 0x20,
-	0x78, 0x1f, 0xc3, 0x8b, 0x0f, 0x1a, 0xce, 0xf2, 0x21, 0xff, 0x32, 0xe3, 0xb9, 0x0a, 0xbe, 0x3b,
-	0xb0, 0xa5, 0xe1, 0xdb, 0x34, 0x51, 0x05, 0xc2, 0x3e, 0x74, 0x3e, 0x8b, 0x5c, 0xa5, 0x6c, 0xca,
-	0xfd, 0xc6, 0xc3, 0xc6, 0x61, 0x77, 0xb8, 0x38, 0x23, 0x42, 0x4b, 0x8a, 0x4c, 0xf9, 0x0e, 0x71,
-	0x8a, 0xf1, 0x09, 0x00, 0xe9, 0x47, 0x32, 0xe3, 0x9f, 0xfc, 0xa6, 0xce, 0x6c, 0x9d, 0x6c, 0x1c,
-	0xcb, 0xd1, 0xb1, 0xd6, 0x0d, 0x4d, 0x62, 0xd8, 0xa5, 0x7c, 0xa8, 0xd3, 0x78, 0x0f, 0x3a, 0x89,
-	0x8c, 0x46, 0x13, 0x11, 0xdf, 0xf8, 0x2d, 0x12, 0x69, 0x27, 0xf2, 0x95, 0x39, 0xa2, 0x07, 0xcd,
-	0x71, 0x9a, 0xfb, 0x6b, 0x44, 0x4d, 0x88, 0x8f, 0xc1, 0xbb, 0xe1, 0x5c, 0xb2, 0x49, 0x32, 0xe7,
-	0x91, 0xe4, 0x59, 0x22, 0xc6, 0xbe, 0x4b, 0xe9, 0xed, 0x05, 0x0f, 0x09, 0xeb, 0x26, 0x76, 0x96,
-	0xa5, 0x2a, 0x99, 0x72, 0x31, 0x53, 0x7e, 0x9b, 0x6a, 0x97, 0x1a, 0x97, 0x96, 0xe3, 0x3e, 0xb4,
-	0x67, 0x39, 0x8f, 0x26, 0xb7, 0xc2, 0xef, 0xe8, 0x92, 0xce, 0xd0, 0xd5, 0xc7, 0xf3, 0x5b, 0x11,
-	0xbc, 0x20, 0x87, 0xae, 0xe4, 0x98, 0x29, 0x5e, 0xda, 0x51, 0xed, 0xb8, 0xf1, 0xcf, 0x8e, 0x9d,
-	0x45, 0xc7, 0xc1, 0x2e, 0xec, 0x68, 0x81, 0xa1, 0xbe, 0xc7, 0xb2, 0xd2, 0xd0, 0xe0, 0x97, 0x43,
-	0xb4, 0x34, 0x3e, 0x97, 0x7a, 0x24, 0x64, 0x65, 0xc5, 0x62, 0x8a, 0xf1, 0x11, 0x6c, 0xe6, 0xfa,
-	0x3d, 0x6c, 0x12, 0xa5, 0xb3, 0xe9, 0x88, 0x67, 0x85, 0xf4, 0x86, 0x85, 0x17, 0xc4, 0x6a, 0xf3,
-	0x69, 0xfe, 0x67, 0x3e, 0xad, 0xca, 0x7c, 0x34, 0x8b, 0xb9, 0x66, 0xd6, 0x58, 0x8a, 0x8d, 0x03,
-	0x31, 0x8b, 0x08, 0x5b, 0x43, 0xdd, 0x98, 0x9d, 0x9a, 0x84, 0x7e, 0x52, 0xca, 0x4b, 0xe7, 0x4c,
-	0x68, 0xae, 0x4f, 0x59, 0x7e, 0x43, 0x4e, 0xe9, 0xeb, 0x26, 0xc6, 0x03, 0x80, 0x38, 0xe3, 0xda,
-	0xa4, 0x71, 0xc4, 0x94, 0xdf, 0xa5, 0x4c, 0xb7, 0x20, 0x2f, 0x15, 0xf6, 0x60, 0x8d, 0x26, 0xee,
-	0x03, 0x65, 0xec, 0xa1, 0x74, 0x6b, 0x7d, 0x39, 0x5f, 0x2d, 0xc3, 0xbf, 0xca, 0x24, 0xe3, 0xb9,
-	0x91, 0xd9, 0xb0, 0x32, 0x05, 0xd1, 0x32, 0x01, 0x6c, 0xea, 0x26, 0x2b, 0x15, 0x9b, 0x54, 0xb1,
-	0x1e, 0xb3, 0xb3, 0xb2, 0x26, 0xd8, 0x81, 0xed, 0xc5, 0xfa, 0x5a, 0x63, 0x8b, 0x19, 0x94, 0x43,
-	0x2c, 0x60, 0x0f, 0xb0, 0x3a, 0x18, 0x4b, 0x8f, 0x0e, 0xa1, 0x53, 0x2e, 0x29, 0x02, 0xb8, 0x17,
-	0xef, 0xc2, 0xe1, 0xd9, 0x1b, 0xef, 0x0e, 0xb6, 0xa1, 0x79, 0xf5, 0x3a, 0xf4, 0x1a, 0x26, 0xb8,
-	0x3c, 0x0d, 0x3d, 0xe7, 0xe4, 0xb7, 0x03, 0x60, 0x66, 0xc8, 0xb3, 0x79, 0x12, 0x73, 0x7c, 0x0f,
-	0xae, 0x1d, 0x27, 0xf6, 0x8a, 0x4d, 0xaf, 0x7d, 0xab, 0xfe, 0xde, 0x0a, 0x2d, 0xba, 0xe8, 0x7f,
-	0xfb, 0xf9, 0xe7, 0x87, 0xd3, 0x43, 0xa4, 0x1f, 0x3a, 0x7f, 0x3a, 0xd0, 0xdf, 0x77, 0x90, 0x5b,
-	0xa1, 0x73, 0x68, 0x99, 0x67, 0x20, 0x16, 0x57, 0x2b, 0x5f, 0xb2, 0xbf, 0x5b, 0x63, 0x85, 0xd8,
-	0x7d, 0x12, 0xdb, 0x0b, 0xbc, 0xaa, 0x58, 0xa2, 0x2b, 0x9e, 0x37, 0x8e, 0xf0, 0x12, 0x5c, 0xeb,
-	0xc0, 0xa2, 0xc1, 0xda, 0x56, 0x2f, 0x1a, 0x5c, 0xb1, 0xe9, 0x80, 0x34, 0xf7, 0x83, 0x5a, 0x83,
-	0x33, 0xaa, 0x31, 0xaa, 0x57, 0xd0, 0x2e, 0x2c, 0xc4, 0x52, 0xa0, 0xbe, 0xeb, 0xfd, 0xbb, 0xab,
-	0x78, 0xa5, 0xd9, 0xdd, 0xaa, 0x70, 0x66, 0x8b, 0x46, 0x2e, 0x2d, 0xc8, 0xb3, 0xbf, 0x01, 0x00,
-	0x00, 0xff, 0xff, 0xba, 0x04, 0x57, 0xbd, 0xce, 0x04, 0x00, 0x00,
-}