//
//Сервис реализует поток изменений ресурсов домена Телеметрии

// Code generated by protoc-gen-go-grpc. DO NOT EDIT.
// versions:
// - protoc-gen-go-grpc v1.3.0
// - protoc             v4.23.1
// source: keyapis/telemetry_control/v1/keyapis_telemetry_control_stream_v1.proto

package keyapis_telemetry_control_v1

import (
	context "context"
	grpc "google.golang.org/grpc"
	codes "google.golang.org/grpc/codes"
	status "google.golang.org/grpc/status"
)

// This is a compile-time assertion to ensure that this generated file
// is compatible with the grpc package it is being compiled against.
// Requires gRPC-Go v1.32.0 or later.
const _ = grpc.SupportPackageIsVersion7

const (
	StreamService_PostResourceFullDuplex_FullMethodName = "/keyapis.telemetry_control.v1.StreamService/PostResourceFullDuplex"
)

// StreamServiceClient is the client API for StreamService service.
//
// For semantics around ctx use and closing/ending streaming RPCs, please refer to https://pkg.go.dev/google.golang.org/grpc/?tab=doc#ClientConn.NewStream.
type StreamServiceClient interface {
	// Полнодуплексный отправки статусов получения ресурсов на сервер и получения изменения ресурсов со стороны сервера.
	// Метод доступен для: ApiKey: Без учета разрешений. С контролем привязки домов к группе
	PostResourceFullDuplex(ctx context.Context, opts ...grpc.CallOption) (StreamService_PostResourceFullDuplexClient, error)
}

type streamServiceClient struct {
	cc grpc.ClientConnInterface
}

func NewStreamServiceClient(cc grpc.ClientConnInterface) StreamServiceClient {
	return &streamServiceClient{cc}
}

func (c *streamServiceClient) PostResourceFullDuplex(ctx context.Context, opts ...grpc.CallOption) (StreamService_PostResourceFullDuplexClient, error) {
	stream, err := c.cc.NewStream(ctx, &StreamService_ServiceDesc.Streams[0], StreamService_PostResourceFullDuplex_FullMethodName, opts...)
	if err != nil {
		return nil, err
	}
	x := &streamServicePostResourceFullDuplexClient{stream}
	return x, nil
}

type StreamService_PostResourceFullDuplexClient interface {
	Send(*PostResourceFullDuplexRequest) error
	Recv() (*PostResourceFullDuplexResponse, error)
	grpc.ClientStream
}

type streamServicePostResourceFullDuplexClient struct {
	grpc.ClientStream
}

func (x *streamServicePostResourceFullDuplexClient) Send(m *PostResourceFullDuplexRequest) error {
	return x.ClientStream.SendMsg(m)
}

func (x *streamServicePostResourceFullDuplexClient) Recv() (*PostResourceFullDuplexResponse, error) {
	m := new(PostResourceFullDuplexResponse)
	if err := x.ClientStream.RecvMsg(m); err != nil {
		return nil, err
	}
	return m, nil
}

// StreamServiceServer is the server API for StreamService service.
// All implementations should embed UnimplementedStreamServiceServer
// for forward compatibility
type StreamServiceServer interface {
	// Полнодуплексный отправки статусов получения ресурсов на сервер и получения изменения ресурсов со стороны сервера.
	// Метод доступен для: ApiKey: Без учета разрешений. С контролем привязки домов к группе
	PostResourceFullDuplex(StreamService_PostResourceFullDuplexServer) error
}

// UnimplementedStreamServiceServer should be embedded to have forward compatible implementations.
type UnimplementedStreamServiceServer struct {
}

func (UnimplementedStreamServiceServer) PostResourceFullDuplex(StreamService_PostResourceFullDuplexServer) error {
	return status.Errorf(codes.Unimplemented, "method PostResourceFullDuplex not implemented")
}

// UnsafeStreamServiceServer may be embedded to opt out of forward compatibility for this service.
// Use of this interface is not recommended, as added methods to StreamServiceServer will
// result in compilation errors.
type UnsafeStreamServiceServer interface {
	mustEmbedUnimplementedStreamServiceServer()
}

func RegisterStreamServiceServer(s grpc.ServiceRegistrar, srv StreamServiceServer) {
	s.RegisterService(&StreamService_ServiceDesc, srv)
}

func _StreamService_PostResourceFullDuplex_Handler(srv interface{}, stream grpc.ServerStream) error {
	return srv.(StreamServiceServer).PostResourceFullDuplex(&streamServicePostResourceFullDuplexServer{stream})
}

type StreamService_PostResourceFullDuplexServer interface {
	Send(*PostResourceFullDuplexResponse) error
	Recv() (*PostResourceFullDuplexRequest, error)
	grpc.ServerStream
}

type streamServicePostResourceFullDuplexServer struct {
	grpc.ServerStream
}

func (x *streamServicePostResourceFullDuplexServer) Send(m *PostResourceFullDuplexResponse) error {
	return x.ServerStream.SendMsg(m)
}

func (x *streamServicePostResourceFullDuplexServer) Recv() (*PostResourceFullDuplexRequest, error) {
	m := new(PostResourceFullDuplexRequest)
	if err := x.ServerStream.RecvMsg(m); err != nil {
		return nil, err
	}
	return m, nil
}

// StreamService_ServiceDesc is the grpc.ServiceDesc for StreamService service.
// It's only intended for direct use with grpc.RegisterService,
// and not to be introspected or modified (even as a copy)
var StreamService_ServiceDesc = grpc.ServiceDesc{
	ServiceName: "keyapis.telemetry_control.v1.StreamService",
	HandlerType: (*StreamServiceServer)(nil),
	Methods:     []grpc.MethodDesc{},
	Streams: []grpc.StreamDesc{
		{
			StreamName:    "PostResourceFullDuplex",
			Handler:       _StreamService_PostResourceFullDuplex_Handler,
			ServerStreams: true,
			ClientStreams: true,
		},
	},
	Metadata: "keyapis/telemetry_control/v1/keyapis_telemetry_control_stream_v1.proto",
}
