livekit-protocol 0.7.5

Livekit protocol and utilities for the Rust SDK
Documentation
// Code generated by protoc-gen-psrpc v0.7.0, DO NOT EDIT.
// source: rpc/agent.proto

package rpc

import (
	"context"

	"github.com/livekit/psrpc"
	"github.com/livekit/psrpc/pkg/client"
	"github.com/livekit/psrpc/pkg/info"
	"github.com/livekit/psrpc/pkg/rand"
	"github.com/livekit/psrpc/pkg/server"
	"github.com/livekit/psrpc/version"
)
import google_protobuf "google.golang.org/protobuf/types/known/emptypb"
import livekit2 "github.com/livekit/protocol/livekit"

var _ = version.PsrpcVersion_0_7

// ==============================
// AgentInternal Client Interface
// ==============================

type AgentInternalClient interface {
	CheckEnabled(ctx context.Context, req *CheckEnabledRequest, opts ...psrpc.RequestOption) (<-chan *psrpc.Response[*CheckEnabledResponse], error)

	JobRequest(ctx context.Context, namespace string, jobType string, req *livekit2.Job, opts ...psrpc.RequestOption) (*JobRequestResponse, error)

	JobTerminate(ctx context.Context, jobId string, req *JobTerminateRequest, opts ...psrpc.RequestOption) (*JobTerminateResponse, error)

	SubscribeWorkerRegistered(ctx context.Context, handlerNamespace string) (psrpc.Subscription[*google_protobuf.Empty], error)

	// Close immediately, without waiting for pending RPCs
	Close()
}

// ==================================
// AgentInternal ServerImpl Interface
// ==================================

type AgentInternalServerImpl interface {
	CheckEnabled(context.Context, *CheckEnabledRequest) (*CheckEnabledResponse, error)

	JobRequest(context.Context, *livekit2.Job) (*JobRequestResponse, error)
	JobRequestAffinity(context.Context, *livekit2.Job) float32

	JobTerminate(context.Context, *JobTerminateRequest) (*JobTerminateResponse, error)
}

// ==============================
// AgentInternal Server Interface
// ==============================

type AgentInternalServer interface {
	RegisterJobRequestTopic(namespace string, jobType string) error
	DeregisterJobRequestTopic(namespace string, jobType string)
	RegisterJobTerminateTopic(jobId string) error
	DeregisterJobTerminateTopic(jobId string)
	PublishWorkerRegistered(ctx context.Context, handlerNamespace string, msg *google_protobuf.Empty) error

	// Close and wait for pending RPCs to complete
	Shutdown()

	// Close immediately, without waiting for pending RPCs
	Kill()
}

// ====================
// AgentInternal Client
// ====================

type agentInternalClient struct {
	client *client.RPCClient
}

// NewAgentInternalClient creates a psrpc client that implements the AgentInternalClient interface.
func NewAgentInternalClient(bus psrpc.MessageBus, opts ...psrpc.ClientOption) (AgentInternalClient, error) {
	sd := &info.ServiceDefinition{
		Name: "AgentInternal",
		ID:   rand.NewClientID(),
	}

	sd.RegisterMethod("CheckEnabled", false, true, false, false)
	sd.RegisterMethod("JobRequest", true, false, true, false)
	sd.RegisterMethod("JobTerminate", false, false, true, true)
	sd.RegisterMethod("WorkerRegistered", false, true, false, false)

	rpcClient, err := client.NewRPCClient(sd, bus, opts...)
	if err != nil {
		return nil, err
	}

	return &agentInternalClient{
		client: rpcClient,
	}, nil
}

func (c *agentInternalClient) CheckEnabled(ctx context.Context, req *CheckEnabledRequest, opts ...psrpc.RequestOption) (<-chan *psrpc.Response[*CheckEnabledResponse], error) {
	return client.RequestMulti[*CheckEnabledResponse](ctx, c.client, "CheckEnabled", nil, req, opts...)
}

func (c *agentInternalClient) JobRequest(ctx context.Context, namespace string, jobType string, req *livekit2.Job, opts ...psrpc.RequestOption) (*JobRequestResponse, error) {
	return client.RequestSingle[*JobRequestResponse](ctx, c.client, "JobRequest", []string{namespace, jobType}, req, opts...)
}

func (c *agentInternalClient) JobTerminate(ctx context.Context, jobId string, req *JobTerminateRequest, opts ...psrpc.RequestOption) (*JobTerminateResponse, error) {
	return client.RequestSingle[*JobTerminateResponse](ctx, c.client, "JobTerminate", []string{jobId}, req, opts...)
}

func (c *agentInternalClient) SubscribeWorkerRegistered(ctx context.Context, handlerNamespace string) (psrpc.Subscription[*google_protobuf.Empty], error) {
	return client.Join[*google_protobuf.Empty](ctx, c.client, "WorkerRegistered", []string{handlerNamespace})
}

func (s *agentInternalClient) Close() {
	s.client.Close()
}

// ====================
// AgentInternal Server
// ====================

type agentInternalServer struct {
	svc AgentInternalServerImpl
	rpc *server.RPCServer
}

// NewAgentInternalServer builds a RPCServer that will route requests
// to the corresponding method in the provided svc implementation.
func NewAgentInternalServer(svc AgentInternalServerImpl, bus psrpc.MessageBus, opts ...psrpc.ServerOption) (AgentInternalServer, error) {
	sd := &info.ServiceDefinition{
		Name: "AgentInternal",
		ID:   rand.NewServerID(),
	}

	s := server.NewRPCServer(sd, bus, opts...)

	sd.RegisterMethod("CheckEnabled", false, true, false, false)
	var err error
	err = server.RegisterHandler(s, "CheckEnabled", nil, svc.CheckEnabled, nil)
	if err != nil {
		s.Close(false)
		return nil, err
	}

	sd.RegisterMethod("JobRequest", true, false, true, false)
	sd.RegisterMethod("JobTerminate", false, false, true, true)
	sd.RegisterMethod("WorkerRegistered", false, true, false, false)
	return &agentInternalServer{
		svc: svc,
		rpc: s,
	}, nil
}

func (s *agentInternalServer) RegisterJobRequestTopic(namespace string, jobType string) error {
	return server.RegisterHandler(s.rpc, "JobRequest", []string{namespace, jobType}, s.svc.JobRequest, s.svc.JobRequestAffinity)
}

func (s *agentInternalServer) DeregisterJobRequestTopic(namespace string, jobType string) {
	s.rpc.DeregisterHandler("JobRequest", []string{namespace, jobType})
}

func (s *agentInternalServer) RegisterJobTerminateTopic(jobId string) error {
	return server.RegisterHandler(s.rpc, "JobTerminate", []string{jobId}, s.svc.JobTerminate, nil)
}

func (s *agentInternalServer) DeregisterJobTerminateTopic(jobId string) {
	s.rpc.DeregisterHandler("JobTerminate", []string{jobId})
}

func (s *agentInternalServer) PublishWorkerRegistered(ctx context.Context, handlerNamespace string, msg *google_protobuf.Empty) error {
	return s.rpc.Publish(ctx, "WorkerRegistered", []string{handlerNamespace}, msg)
}

func (s *agentInternalServer) Shutdown() {
	s.rpc.Close(false)
}

func (s *agentInternalServer) Kill() {
	s.rpc.Close(true)
}

// ==================================
// AgentInternal Unimplemented Server
// ==================================

type UnimplementedAgentInternalServer struct{}

func (UnimplementedAgentInternalServer) CheckEnabled(context.Context, *CheckEnabledRequest) (*CheckEnabledResponse, error) {
	return nil, psrpc.ErrUnimplemented
}

func (UnimplementedAgentInternalServer) JobRequest(context.Context, *livekit2.Job) (*JobRequestResponse, error) {
	return nil, psrpc.ErrUnimplemented
}
func (UnimplementedAgentInternalServer) JobRequestAffinity(context.Context, *livekit2.Job) float32 {
	return -1
}

func (UnimplementedAgentInternalServer) JobTerminate(context.Context, *JobTerminateRequest) (*JobTerminateResponse, error) {
	return nil, psrpc.ErrUnimplemented
}

func (UnimplementedAgentInternalServer) WorkerRegistered(context.Context, *google_protobuf.Empty) (*google_protobuf.Empty, error) {
	return nil, psrpc.ErrUnimplemented
}

var psrpcFileDescriptor0 = []byte{
	// 588 bytes of a gzipped FileDescriptorProto
	0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x94, 0x54, 0x4f, 0x6e, 0xd3, 0x4e,
	0x18, 0xfd, 0x4d, 0xfa, 0x47, 0xc9, 0x34, 0xfd, 0xd5, 0x1d, 0xb7, 0x90, 0x1a, 0xa1, 0xb6, 0xde,
	0x50, 0x01, 0xb2, 0x51, 0x59, 0x23, 0x9a, 0x10, 0x83, 0x12, 0x91, 0x44, 0xb8, 0x2e, 0x48, 0x6c,
	0x2c, 0xdb, 0xf9, 0x70, 0xdc, 0x38, 0x9e, 0x61, 0x3c, 0x41, 0xea, 0x11, 0x72, 0x05, 0x8e, 0x91,
	0xf3, 0x70, 0x04, 0x96, 0x1c, 0x00, 0x79, 0xec, 0x18, 0xa7, 0x0a, 0x0b, 0x56, 0xd1, 0xbc, 0xf7,
	0xf2, 0xe9, 0x7b, 0xef, 0xcd, 0x18, 0x1f, 0x70, 0x16, 0x98, 0x5e, 0x08, 0x89, 0x30, 0x18, 0xa7,
	0x82, 0x92, 0x2d, 0xce, 0x02, 0xed, 0x51, 0x48, 0x69, 0x18, 0x83, 0x29, 0x21, 0x7f, 0xfe, 0xc5,
	0x84, 0x19, 0x13, 0x77, 0xb9, 0x42, 0xdb, 0xa7, 0x4c, 0x44, 0x34, 0x49, 0x8b, 0xa3, 0x1a, 0x47,
	0xdf, 0x60, 0x1a, 0x09, 0xb7, 0x32, 0x45, 0x3b, 0x8a, 0x69, 0x18, 0x02, 0x37, 0xd7, 0xa4, 0xfa,
	0x31, 0x56, 0xdf, 0x4c, 0x20, 0x98, 0x5a, 0x89, 0xe7, 0xc7, 0x30, 0xb6, 0xe1, 0xeb, 0x1c, 0x52,
	0xa1, 0xff, 0x40, 0xf8, 0x68, 0x1d, 0x4f, 0x19, 0x4d, 0x52, 0x20, 0xe7, 0xb8, 0xc9, 0x29, 0x9d,
	0xb9, 0x90, 0xe3, 0x2d, 0x74, 0x86, 0x2e, 0xea, 0xf6, 0x5e, 0x86, 0x15, 0x52, 0xf2, 0x0c, 0x1f,
	0xb2, 0xb9, 0x1f, 0x47, 0xe9, 0x04, 0x78, 0xa9, 0xab, 0x49, 0x9d, 0x52, 0x12, 0x2b, 0xb1, 0x89,
	0x55, 0xe6, 0x71, 0x11, 0x05, 0x11, 0xf3, 0x12, 0x51, 0xca, 0x77, 0xa4, 0x9c, 0x54, 0xa8, 0xd5,
	0x1f, 0x74, 0x8c, 0x13, 0x6f, 0x06, 0x29, 0xf3, 0x02, 0x48, 0x5b, 0x5b, 0x67, 0x5b, 0x17, 0x8d,
	0x4e, 0xad, 0x85, 0xec, 0x0a, 0x4a, 0x4e, 0xf1, 0x9e, 0x74, 0xee, 0x4a, 0xac, 0xb5, 0x9d, 0x89,
	0x6c, 0x2c, 0xa1, 0x61, 0x86, 0xe8, 0xaf, 0x30, 0xe9, 0x53, 0xbf, 0x30, 0x5b, 0x7a, 0x7b, 0x82,
	0x77, 0x52, 0xe1, 0x09, 0x90, 0xa6, 0xf6, 0x2e, 0x0f, 0x8d, 0x22, 0x46, 0xa3, 0x4f, 0xfd, 0xeb,
	0x8c, 0xb0, 0x73, 0x5e, 0x9f, 0x60, 0xb5, 0x4f, 0x7d, 0x07, 0xf8, 0x2c, 0x4a, 0x32, 0x38, 0x9f,
	0x43, 0xce, 0xf0, 0xee, 0x2d, 0xf5, 0xdd, 0x28, 0x4f, 0xa5, 0xd1, 0x69, 0x7c, 0xff, 0xf9, 0x7c,
	0xe7, 0x96, 0xfa, 0xbd, 0xae, 0x2d, 0x7f, 0x32, 0xb7, 0xbb, 0x1c, 0xbc, 0x94, 0x26, 0x32, 0x8f,
	0xff, 0x2f, 0x1f, 0x1a, 0x9c, 0x05, 0xc6, 0xfa, 0xac, 0x8c, 0xb6, 0x0b, 0x99, 0xfe, 0x1a, 0x1f,
	0xad, 0xb3, 0xff, 0xb8, 0xea, 0xd3, 0xae, 0x74, 0x7a, 0x6f, 0x3c, 0x39, 0xc1, 0xc7, 0x8e, 0x65,
	0x0f, 0x7a, 0xc3, 0xb6, 0xd3, 0x1b, 0x0d, 0x5d, 0xdb, 0xfa, 0x70, 0x63, 0x5d, 0x3b, 0x56, 0x57,
	0xf9, 0x8f, 0xa8, 0xf8, 0xa0, 0xfd, 0xce, 0x1a, 0x3a, 0xee, 0x7b, 0xeb, 0xad, 0xe3, 0xda, 0xa3,
	0xd1, 0x40, 0x41, 0x97, 0xbf, 0x6a, 0x78, 0xbf, 0x9d, 0xc5, 0xd7, 0x4b, 0x04, 0xf0, 0xc4, 0x8b,
	0xc9, 0x00, 0x37, 0xab, 0xf7, 0x83, 0xb4, 0xa4, 0x93, 0x0d, 0x57, 0x49, 0x3b, 0xd9, 0xc0, 0xe4,
	0x2e, 0xf4, 0xfa, 0x72, 0x81, 0xb6, 0xaf, 0x6a, 0x17, 0x88, 0x7c, 0xc4, 0xf8, 0x4f, 0x21, 0xa4,
	0x59, 0xb5, 0xa3, 0x95, 0x21, 0xdd, 0xeb, 0x4b, 0x3f, 0x5f, 0x2e, 0xd0, 0x63, 0x05, 0x69, 0xc7,
	0xa4, 0x51, 0x96, 0x4f, 0xea, 0x59, 0x05, 0xe2, 0x8e, 0xc1, 0x15, 0x7a, 0x81, 0xc8, 0x0d, 0x6e,
	0x56, 0xed, 0x17, 0x6b, 0x6e, 0x28, 0xaf, 0x58, 0x73, 0x53, 0xd8, 0xba, 0xb2, 0x5c, 0xa0, 0xa6,
	0x82, 0xb4, 0x3a, 0x29, 0xfa, 0x25, 0x80, 0x95, 0x4f, 0x94, 0x4f, 0x81, 0xdb, 0x10, 0x46, 0xa9,
	0x00, 0x0e, 0x63, 0xf2, 0xc0, 0xc8, 0x5f, 0xa8, 0xb1, 0x7a, 0xa1, 0x86, 0x95, 0xbd, 0x50, 0xed,
	0x2f, 0x78, 0xbe, 0x7d, 0x1d, 0x29, 0x48, 0x53, 0xc9, 0xe1, 0xc4, 0x4b, 0xc6, 0x31, 0x70, 0xb7,
	0xf4, 0x91, 0xa5, 0xd2, 0x39, 0xff, 0x7c, 0x1a, 0x46, 0x62, 0x32, 0xf7, 0x8d, 0x80, 0xce, 0xcc,
	0x22, 0x93, 0xfc, 0x0b, 0x10, 0xd0, 0xd8, 0xe4, 0x2c, 0xf0, 0x77, 0xe5, 0xe9, 0xe5, 0xef, 0x00,
	0x00, 0x00, 0xff, 0xff, 0x3d, 0xdc, 0xa6, 0x53, 0x35, 0x04, 0x00, 0x00,
}