JSON

Struct JSON 

Source
pub struct JSON(/* private fields */);
Expand description

A CBOR-tagged container for UTF-8 JSON text.

The JSON type wraps UTF-8 JSON text as a CBOR byte string with tag 262. This allows JSON data to be embedded within CBOR structures while maintaining type information through the tag.

This implementation does not validate that the contained data is well-formed JSON. It simply provides a type-safe wrapper around byte data that is intended to contain JSON text.

§CBOR Serialization

JSON implements the CBORTaggedCodable trait, which means it can be serialized to and deserialized from CBOR with tag 262 (TAG_JSON).

§Examples

Creating JSON from a string:

use bc_components::JSON;

let json = JSON::from_string(r#"{"key": "value"}"#);
assert_eq!(json.as_str(), r#"{"key": "value"}"#);

Creating JSON from bytes:

use bc_components::JSON;

let json = JSON::from_data(b"[1, 2, 3]");
assert_eq!(json.len(), 9);

Implementations§

Source§

impl JSON

Source

pub fn len(&self) -> usize

Return the length of the JSON data in bytes.

Source

pub fn is_empty(&self) -> bool

Return true if the JSON data is empty.

Source

pub fn from_data(data: impl AsRef<[u8]>) -> Self

Create a new JSON instance from byte data.

Source

pub fn from_string(s: impl AsRef<str>) -> Self

Create a new JSON instance from a string.

Source

pub fn as_bytes(&self) -> &[u8]

Return the data as a byte slice.

Source

pub fn as_str(&self) -> &str

Return the data as a UTF-8 string slice.

§Panics

Panics if the data is not valid UTF-8.

Source

pub fn from_hex(hex: impl AsRef<str>) -> Self

Create a new JSON instance from a hexadecimal string.

Source

pub fn hex(&self) -> String

Return the data as a hexadecimal string.

Trait Implementations§

Source§

impl AsRef<[u8]> for JSON

Allows using a JSON as a reference to a byte slice.

Source§

fn as_ref(&self) -> &[u8]

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl AsRef<JSON> for JSON

Provides a self-reference, enabling API consistency with other types.

Source§

fn as_ref(&self) -> &JSON

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl CBORTagged for JSON

Identifies the CBOR tags used for JSON serialization.

Source§

fn cbor_tags() -> Vec<Tag>

Returns the CBOR tags associated with this type. Read more
Source§

impl CBORTaggedDecodable for JSON

Defines how JSON is decoded from CBOR.

Source§

fn from_untagged_cbor(untagged_cbor: CBOR) -> Result<Self>

Creates an instance of this type by decoding it from untagged CBOR. Read more
Source§

fn from_tagged_cbor(cbor: CBOR) -> Result<Self, Error>
where Self: Sized,

Creates an instance of this type by decoding it from tagged CBOR. Read more
Source§

fn from_tagged_cbor_data(data: impl AsRef<[u8]>) -> Result<Self, Error>
where Self: Sized,

Creates an instance of this type by decoding it from binary encoded tagged CBOR. Read more
Source§

fn from_untagged_cbor_data(data: impl AsRef<[u8]>) -> Result<Self, Error>
where Self: Sized,

Creates an instance of this type by decoding it from binary encoded untagged CBOR. Read more
Source§

impl CBORTaggedEncodable for JSON

Defines how JSON is encoded as CBOR (as a byte string).

Source§

fn untagged_cbor(&self) -> CBOR

Returns the untagged CBOR encoding of this instance. Read more
Source§

fn tagged_cbor(&self) -> CBOR

Returns the tagged CBOR encoding of this instance. Read more
Source§

fn tagged_cbor_data(&self) -> Vec<u8>

Returns the tagged value in CBOR binary representation. Read more
Source§

impl Clone for JSON

Source§

fn clone(&self) -> JSON

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for JSON

Provides a debug representation showing the JSON data as a string.

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'a> From<&'a JSON> for &'a [u8]

Allows accessing the underlying data as a byte slice reference.

Source§

fn from(value: &'a JSON) -> Self

Converts to this type from the input type.
Source§

impl From<&JSON> for JSON

Enables cloning a JSON from a reference using From trait.

Source§

fn from(json: &JSON) -> Self

Converts to this type from the input type.
Source§

impl From<&JSON> for Vec<u8>

Converts a JSON reference into a Vec<u8> containing the JSON bytes.

Source§

fn from(json: &JSON) -> Self

Converts to this type from the input type.
Source§

impl From<JSON> for CBOR

Enables conversion of JSON into a tagged CBOR value.

Source§

fn from(value: JSON) -> Self

Converts to this type from the input type.
Source§

impl From<JSON> for Vec<u8>

Converts JSON into a Vec<u8> containing the JSON bytes.

Source§

fn from(json: JSON) -> Self

Converts to this type from the input type.
Source§

impl PartialEq for JSON

Source§

fn eq(&self, other: &JSON) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl TryFrom<CBOR> for JSON

Enables conversion from CBOR to JSON, with proper error handling.

Source§

type Error = Error

The type returned in the event of a conversion error.
Source§

fn try_from(cbor: CBOR) -> Result<Self>

Performs the conversion.
Source§

impl Eq for JSON

Source§

impl StructuralPartialEq for JSON

Auto Trait Implementations§

§

impl Freeze for JSON

§

impl RefUnwindSafe for JSON

§

impl Send for JSON

§

impl Sync for JSON

§

impl Unpin for JSON

§

impl UnwindSafe for JSON

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CBORDecodable for T
where T: TryFrom<CBOR, Error = Error>,

Source§

fn try_from_cbor(cbor: &CBOR) -> Result<Self, Error>

Source§

impl<T> CBOREncodable for T
where T: Into<CBOR> + Clone,

Source§

fn to_cbor(&self) -> CBOR

Converts this value to a CBOR object. Read more
Source§

fn to_cbor_data(&self) -> Vec<u8>

Converts this value directly to binary CBOR data. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToHex for T
where T: AsRef<[u8]>,

Source§

fn encode_hex<U>(&self) -> U
where U: FromIterator<char>,

Encode the hex strict representing self into the result. Lower case letters are used (e.g. f9b4ca)
Source§

fn encode_hex_upper<U>(&self) -> U
where U: FromIterator<char>,

Encode the hex strict representing self into the result. Upper case letters are used (e.g. F9B4CA)
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> URDecodable for T

Source§

fn from_ur(ur: impl AsRef<UR>) -> Result<Self, Error>
where Self: Sized,

Source§

fn from_ur_string(ur_string: impl Into<String>) -> Result<Self, Error>
where Self: Sized,

Source§

impl<T> UREncodable for T

Source§

fn ur(&self) -> UR

Returns the UR representation of the object.
Source§

fn ur_string(&self) -> String

Returns the UR string representation of the object.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> CBORCodable for T

Source§

impl<T> CBORTaggedCodable for T

Source§

impl<T> URCodable for T