#schema #protocols #bindings #applications #schema-version #data #receipt

versa

Versa types and utilities for developing Versa client applications in Rust

27 releases (10 breaking)

new 0.20.0 Jan 14, 2025
0.19.1 Dec 10, 2024
0.18.0 Nov 20, 2024

#1977 in Database interfaces

Download history 159/week @ 2024-09-26 16/week @ 2024-10-03 1340/week @ 2024-10-10 706/week @ 2024-10-17 332/week @ 2024-10-24 139/week @ 2024-10-31 479/week @ 2024-11-07 117/week @ 2024-11-14 107/week @ 2024-11-21 56/week @ 2024-11-28 218/week @ 2024-12-05 156/week @ 2024-12-12 10/week @ 2024-12-19 3/week @ 2025-01-02 104/week @ 2025-01-09

133 downloads per month

MIT license

255KB
6K SLoC

Versa Rust

This crate is the official Versa SDK for Rust.

Versa uses semantic versioning to ensure the stability of its data model. The current schema version 1.9.0

You can use this crate broadly in two ways: either just referencing the type bindings, or to implement a custom client in Rust.

You will need to enable either the client_sender or client_receiver feature to leverage the corresponding client implementation.

Type Bindings

There are broadly two kinds of types represented in this repository: Protocol Bindings and the Receipt Schema

This repository references the root JSON schema files, at https://github.com/versa-protocol/schema, to generate the Rust bindings for a Versa receipt.

Protocol Bindings

Protocol Bindings represent the types of requests, responses, and error codes to be expected when developing client implementations according to the specifications of the Versa Protocol. These types are defined in the protocol directory.

Receipt Schema

The Receipt struct represents the receipt and invoice data schemas to be handled when developing client implementations according to the specifications of the Versa Protocol. These types are defined in receipt.rs

Build Process

This crate uses the typify crate to construct the receipt schema bindings from our json schema

Features

  • client Enables Versa client initialization with customer registration APIs
  • client_sender Enables the Versa sending client implementation
  • client_receiver Enables the Versa receiving client implementation
  • diesel Implements diesel traits for MySQL on certain structs (UNSTABLE: Use with caution)

TODO

  • Rust stable crate
  • Expanded diesel database support

Dependencies

~6–19MB
~281K SLoC