Claude-skill-registry librpc

install
source · Clone the upstream repo
git clone https://github.com/majiayu000/claude-skill-registry
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/librpc" ~/.claude/skills/majiayu000-claude-skill-registry-librpc && rm -rf "$T"
manifest: skills/data/librpc/SKILL.md
source content

librpc Skill

When to Use

  • Building gRPC service implementations
  • Creating clients for inter-service calls
  • Adding authentication to gRPC endpoints
  • Implementing distributed tracing across services

Key Concepts

RpcServer: Base server class for gRPC services with middleware support.

RpcClient: Base client class with connection management and error handling.

createClientFactory: Factory that creates typed service clients with optional logging and tracing.

Usage Patterns

Pattern 1: Create service server

import { RpcServer, createService } from "@copilot-ld/librpc";

const service = createService(MyServiceImpl, proto);
const server = new RpcServer([service], config);
await server.start();

Pattern 2: Create service client

import { createClientFactory } from "@copilot-ld/librpc";

const factory = createClientFactory(logger, tracer);
const agentClient = factory.createAgentClient("localhost", 50051);
const response = await agentClient.request(message);

Integration

Used by all services for gRPC communication. Works with libtype for message types.