surrealdb-types 3.0.2

A scalable, distributed, collaborative, document-graph database, for the realtime web
Documentation
# SurrealDB Types

This crate provides the shared public value type system for SurrealDB. It serves as a foundational layer that defines all the data types that can be stored and manipulated in SurrealDB.

## Purpose

The `surrealdb-types` crate acts as a shared public value type system that:

- **Provides type safety**: Offers strongly-typed representations of all SurrealDB data types
- **Enables serialization**: Supports serialization/deserialization of values
- **Facilitates type conversion**: Provides traits and methods for converting between Rust types and SurrealDB values

## Core Types

### Value Types

The main `Value` enum represents all possible data types in SurrealDB:

```rust
use surrealdb_types::{Array, Datetime, Number, Object, Value};
use std::collections::BTreeMap;

// Basic types
let bool_val = Value::Bool(true);
let string_val = Value::String("hello".to_string());
let number_val = Value::Number(Number::Int(42));

// Complex types
let array_val = Value::Array(Array::from(vec![Value::String("item".to_string())]));
let object_val = Value::Object(Object::new());
let datetime_val = Value::Datetime(Datetime::now());
```

### Type System

The `Kind` enum represents the type system used for schema validation and type checking:

```rust
use surrealdb_types::Kind;

// Basic kinds
let string_kind = Kind::String;
let number_kind = Kind::Number;
let array_kind = Kind::Array(Box::new(Kind::String), Some(10)); // Array of strings, max 10 items
```

## Key Features

### Type Conversion

The `SurrealValue` trait provides type-safe conversion between Rust types and SurrealDB values:

```rust
use surrealdb_types::{SurrealValue, Value};

// Convert from Rust type to SurrealDB value
let value: Value = "hello".to_string().into_value();

// Check if a value is of a specific type
if value.is::<String>() {
    println!("Value is a string");
}

// Convert from SurrealDB value to Rust type
let string = value.into_t::<String>().unwrap();
println!("Extracted string: {}", string);
```

### Geometric Types

Support for spatial data types using the `geo` crate:

```rust
use surrealdb_types::{Geometry, Value};
use geo::Point;

let point = Point::new(1.0, 2.0);
let geometry_val = Value::Geometry(Geometry::Point(point));
```

### Record Identifiers

Type-safe representation of SurrealDB record identifiers:

```rust
use surrealdb_types::{RecordId, RecordIdKey, Value};

let record_id = RecordId {
    table: "person".into(),
    key: RecordIdKey::String("john".to_string()),
};
let record_val = Value::RecordId(record_id);
```

## Usage

### Basic Usage

```rust
use surrealdb_types::{Value, Number, Array, Object};
use std::collections::BTreeMap;

// Create values
let values = vec![
    Value::Bool(true),
    Value::Number(Number::Int(42)),
    Value::String("hello".to_string()),
    Value::Array(Array::from(vec![Value::String("item".to_string())])),
];

// Work with objects
let mut map = BTreeMap::new();
map.insert("key".to_string(), Value::String("value".to_string()));
let object = Value::Object(Object::from(map));
```

### Macros for object & array values

This library provides two macros to easily create object and array values. All values you pass to the macro must implement the `SurrealValue` trait.

```rust
use surrealdb_types::{object, array};

let values = array![
    true,
    42,
    "hello".to_string(),
    array!["item1".to_string()],
];

let map = object! {
    key: "value".to_string(),
};
```

### Deriving the `SurrealValue` trait

#### Requirements

- All fields must implement the `SurrealValue` trait

```rust
use surrealdb_types::SurrealValue;

#[derive(SurrealValue)]
struct Person {
    name: String,
    age: i64,
}

let person = Person {
    name: "John".to_string(),
    age: 30,
};

let value = person.into_value();
let person2 = Person::from_value(value).unwrap();

assert_eq!(person2.name, "John");
assert_eq!(person2.age, 30);
```

### Type Checking

```rust
use surrealdb_types::{Value, SurrealValue};

fn process_value(value: &Value) {
    match value {
        Value::String(s) => println!("String: {}", s),
        Value::Number(n) => println!("Number: {:?}", n),
        Value::Array(arr) => println!("Array with {} items", arr.len()),
        _ => println!("Other type"),
    }
}
```

## Dependencies

This crate has minimal external dependencies:

- `serde`: For serialization/deserialization
- `chrono`: For datetime handling
- `uuid`: For UUID support
- `rust_decimal`: For decimal number support
- `regex`: For regular expression support
- `geo`: For geometric types
- `surrealdb-types-derive`: For deriving the `SurrealValue` trait
- `surrealdb-protocol`: For the SurrealDB protocol
- `flatbuffers`: For the FlatBuffers protocol
- `bytes`: For the Bytes type
- `anyhow`: For error handling
- `geo`: For geometric types
- `regex`: For regular expression support
- `rust_decimal`: For decimal number support
- `uuid`: For UUID support
- `rstest`: For testing
- `hex`: For hex encoding

## License

This crate is part of SurrealDB and follows the same licensing terms.