Skip to main content

Protocol Buffer schemas for Tusk Drift

Project description

Tusk Drift Schemas

This repo holds schemas defined as protobuf files used by Tusk Drift. We use Buf to generate code for each language we support (currently TypeScript, Golang, and Python), and prost-build to generate Rust types.

Prerequisites

Before generating schemas, install the following:

  1. Install the Buf CLI.

  2. Python betterproto (for Python code generation):

    pip install "betterproto[compiler]>=2.0.0b7"
    # Or using the requirements file:
    pip install -r requirements.txt
    
  3. Rust toolchain (for Rust schema crate code generation / checks):

    rustup toolchain install 1.93.1
    

    This repo also pins Rust in rust-toolchain.toml.

Generating Schemas

After modifying .proto files, regenerate the code:

npm run generate

Generated package directories:

Language Directory
TypeScript generated/ts
Go generated/go
Python generated/python
Rust rust/src/generated

[!NOTE] Rust generated files live under rust/src/generated so the published crate is self-contained (crates.io packages only include files within the crate directory).

[!NOTE] You may see "duplicate generated file name" warnings from betterproto. These are harmless and can be ignored — they occur because multiple proto packages share the same Python namespace (tusk.drift).

Then build the TypeScript package:

npm run build

[!NOTE] npm run build runs npm run sync:exports before bundling. You do not need to manually edit package.json exports when adding or removing files within the existing TypeScript export roots (generated/ts/*, and src/*). Only update scripts/sync-exports.mjs ENTRY_GROUPS when introducing a brand-new export root directory.

Generate/check Rust schema types:

cargo check -p tusk-drift-schemas

Usage

Installing schemas in TypeScript projects

npm install @use-tusk/drift-schemas

Developing locally:

  • In this repo, run npm link to create a symlink to the local package.
  • In your project, run npm link @use-tusk/drift-schemas to use the local package.
  • After updating the schemas, run npm run build to rebuild the package.
  • Run npm unlink @use-tusk/drift-schemas to remove the local package.

Installing schemas in Golang projects

go get github.com/Use-Tusk/tusk-drift-schemas

When developing locally, add this to go.mod in your project:

replace github.com/Use-Tusk/tusk-drift-schemas => ../tusk-drift-schemas

Run go mod tidy to update the dependencies. Remember to remove this before pushing.

Installing schemas in Python projects

pip install tusk-drift-schemas

Then you can import as

# Core schemas
from tusk.drift.core.v1 import *

# Backend schemas
from tusk.drift.backend.v1 import *

Installing schemas in Rust projects

[dependencies]
tusk-drift-schemas = "0.1.30"

Then import generated protobuf types:

use tusk_drift_schemas::tusk::drift::backend::v1::ExportSpansRequest;
use tusk_drift_schemas::tusk::drift::core::v1::Span;

Releasing

Versioning policy: this repo currently uses lockstep versions across NPM (package.json), PyPI (pyproject.toml), and crates.io packages (rust/Cargo.toml).

Use the release script to create a new release:

# Patch release (0.1.22 → 0.1.23)
./scripts/release.sh

# Minor release (0.1.22 → 0.2.0)
./scripts/release.sh minor

The script will:

  1. Run preflight checks (on main, up to date, no uncommitted changes)
  2. Run generate and build to verify everything works
  3. Update version in package.json, pyproject.toml, and rust/Cargo.toml
  4. Commit, tag, and push to GitHub
  5. Create a GitHub Release (which triggers the NPM & PyPI publish workflows)

[!TIP] If a broken release occurs, or you just want to test some stuff, you can supply an optional version override to the GH actions manually, like 0.1.23.dev1.

Manually publishing from crate directory
cd rust
cargo publish

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tusk_drift_schemas-0.1.33.tar.gz (16.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tusk_drift_schemas-0.1.33-py3-none-any.whl (15.3 kB view details)

Uploaded Python 3

File details

Details for the file tusk_drift_schemas-0.1.33.tar.gz.

File metadata

  • Download URL: tusk_drift_schemas-0.1.33.tar.gz
  • Upload date:
  • Size: 16.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for tusk_drift_schemas-0.1.33.tar.gz
Algorithm Hash digest
SHA256 33b798c2d578073037bb26c62dd2b4ef5956c7f77fa7a256c2c1cd3e6245bcf1
MD5 9533aa6e10074d93f2389cec08ba299c
BLAKE2b-256 099c1fcbc7c3a276b906cc56c4c21cc18f1880508c9700578250919467a2ab8f

See more details on using hashes here.

Provenance

The following attestation bundles were made for tusk_drift_schemas-0.1.33.tar.gz:

Publisher: publish-pypi.yml on Use-Tusk/tusk-drift-schemas

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file tusk_drift_schemas-0.1.33-py3-none-any.whl.

File metadata

File hashes

Hashes for tusk_drift_schemas-0.1.33-py3-none-any.whl
Algorithm Hash digest
SHA256 cdf4938cdf158cb98b206a3c17054425d4a4cf6c6c1b9d31a9d3b68aa0c37611
MD5 4713664f3da8c5e1f7b5c4757297875a
BLAKE2b-256 d289e5b393fff3ae6bb646ae0c2cd4e61c60b08502ef5ef7d7d2b5b689b7d308

See more details on using hashes here.

Provenance

The following attestation bundles were made for tusk_drift_schemas-0.1.33-py3-none-any.whl:

Publisher: publish-pypi.yml on Use-Tusk/tusk-drift-schemas

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page