mirror of
https://github.com/uqbar-dao/nectar.git
synced 2025-01-01 13:05:00 +03:00
fixes
This commit is contained in:
parent
c75eac0527
commit
b892050bc6
@ -362,14 +362,6 @@ async fn handle_request(
|
||||
}
|
||||
}
|
||||
}
|
||||
KvAction::Backup => {
|
||||
// looping through open dbs and flushing their memtables
|
||||
for db_ref in state.open_kvs.iter() {
|
||||
let db = db_ref.value();
|
||||
db.flush().map_err(rocks_to_kv_err)?;
|
||||
}
|
||||
(serde_json::to_vec(&KvResponse::Ok).unwrap(), None)
|
||||
}
|
||||
};
|
||||
|
||||
if let Some(target) = km.rsvp.or_else(|| expects_response.map(|_| source)) {
|
||||
|
@ -2,7 +2,10 @@ use crate::types::core::PackageId;
|
||||
use serde::{Deserialize, Serialize};
|
||||
use thiserror::Error;
|
||||
|
||||
/// IPC Request format for the kv:distro:sys runtime module.
|
||||
/// Actions are sent to a specific key value database. `db` is the name,
|
||||
/// `package_id` is the [`PackageId`] that created the database. Capabilities
|
||||
/// are checked: you can access another process's database if it has given
|
||||
/// you the read and/or write capability to do so.
|
||||
#[derive(Clone, Debug, Serialize, Deserialize)]
|
||||
pub struct KvRequest {
|
||||
pub package_id: PackageId,
|
||||
@ -10,36 +13,74 @@ pub struct KvRequest {
|
||||
pub action: KvAction,
|
||||
}
|
||||
|
||||
/// IPC Action format representing operations that can be performed on the
|
||||
/// key-value runtime module. These actions are included in a [`KvRequest`]
|
||||
/// sent to the `kv:distro:sys` runtime module.
|
||||
#[derive(Clone, Debug, Serialize, Deserialize)]
|
||||
pub enum KvAction {
|
||||
/// Opens an existing key-value database or creates a new one if it doesn't exist.
|
||||
/// Requires `package_id` in [`KvRequest`] to match the package ID of the sender.
|
||||
/// The sender will own the database and can remove it with [`KvAction::RemoveDb`].
|
||||
///
|
||||
/// A successful open will respond with [`KvResponse::Ok`]. Any error will be
|
||||
/// contained in the [`KvResponse::Err`] variant.
|
||||
Open,
|
||||
/// Permanently deletes the entire key-value database.
|
||||
/// Requires `package_id` in [`KvRequest`] to match the package ID of the sender.
|
||||
/// Only the owner can remove the database.
|
||||
///
|
||||
/// A successful remove will respond with [`KvResponse::Ok`]. Any error will be
|
||||
/// contained in the [`KvResponse::Err`] variant.
|
||||
RemoveDb,
|
||||
/// Sets a value for the specified key in the database.
|
||||
///
|
||||
/// # Parameters
|
||||
/// * `key` - The key as a byte vector
|
||||
/// * `tx_id` - Optional transaction ID if this operation is part of a transaction
|
||||
/// * blob: Vec<u8> - Value to store for the key
|
||||
/// * blob: [`Vec<u8>`] - Byte vector to store for the key
|
||||
///
|
||||
/// Using this action requires the sender to have the write capability
|
||||
/// for the database.
|
||||
///
|
||||
/// A successful set will respond with [`KvResponse::Ok`]. Any error will be
|
||||
/// contained in the [`KvResponse::Err`] variant.
|
||||
Set { key: Vec<u8>, tx_id: Option<u64> },
|
||||
/// Deletes a key-value pair from the database.
|
||||
///
|
||||
/// # Parameters
|
||||
/// * `key` - The key to delete as a byte vector
|
||||
/// * `tx_id` - Optional transaction ID if this operation is part of a transaction
|
||||
///
|
||||
/// Using this action requires the sender to have the write capability
|
||||
/// for the database.
|
||||
///
|
||||
/// A successful delete will respond with [`KvResponse::Ok`]. Any error will be
|
||||
/// contained in the [`KvResponse::Err`] variant.
|
||||
Delete { key: Vec<u8>, tx_id: Option<u64> },
|
||||
/// Retrieves the value associated with the specified key.
|
||||
///
|
||||
/// # Parameters
|
||||
/// * `key` - The key to look up as a byte vector
|
||||
/// * The key to look up as a byte vector
|
||||
///
|
||||
/// Using this action requires the sender to have the read capability
|
||||
/// for the database.
|
||||
///
|
||||
/// A successful get will respond with [`KvResponse::Get`], where the response blob
|
||||
/// contains the value associated with the key if any. Any error will be
|
||||
/// contained in the [`KvResponse::Err`] variant.
|
||||
Get(Vec<u8>),
|
||||
/// Begins a new transaction for atomic operations.
|
||||
///
|
||||
/// Sending this will prompt a [`KvResponse::BeginTx`] response with the
|
||||
/// transaction ID. Any error will be contained in the [`KvResponse::Err`] variant.
|
||||
BeginTx,
|
||||
/// Commits all operations in the specified transaction.
|
||||
///
|
||||
/// # Parameters
|
||||
/// * `tx_id` - The ID of the transaction to commit
|
||||
///
|
||||
/// A successful commit will respond with [`KvResponse::Ok`]. Any error will be
|
||||
/// contained in the [`KvResponse::Err`] variant.
|
||||
Commit { tx_id: u64 },
|
||||
}
|
||||
|
||||
@ -55,9 +96,9 @@ pub enum KvResponse {
|
||||
BeginTx { tx_id: u64 },
|
||||
/// Returns the value for the key that was retrieved from the database.
|
||||
///
|
||||
/// # Fields
|
||||
/// * `key` - The retrieved key as a byte vector
|
||||
/// * blob: Vec<u8> - Value associated with the key
|
||||
/// # Parameters
|
||||
/// * The retrieved key as a byte vector
|
||||
/// * blob: [`Vec<u8>`] - Byte vector associated with the key
|
||||
Get(Vec<u8>),
|
||||
/// Indicates an error occurred during the operation.
|
||||
Err(KvError),
|
||||
@ -87,6 +128,11 @@ pub enum KvError {
|
||||
IOError(String),
|
||||
}
|
||||
|
||||
/// The JSON parameters contained in all capabilities issued by `kv:distro:sys`.
|
||||
///
|
||||
/// # Fields
|
||||
/// * `kind` - The kind of capability, either [`KvCapabilityKind::Read`] or [`KvCapabilityKind::Write`]
|
||||
/// * `db_key` - The database key, a tuple of the [`PackageId`] that created the database and the database name
|
||||
#[derive(Clone, Debug, Serialize, Deserialize)]
|
||||
pub struct KvCapabilityParams {
|
||||
pub kind: KvCapabilityKind,
|
||||
@ -100,12 +146,6 @@ pub enum KvCapabilityKind {
|
||||
Write,
|
||||
}
|
||||
|
||||
impl std::fmt::Display for KvAction {
|
||||
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
|
||||
write!(f, "{:?}", self)
|
||||
}
|
||||
}
|
||||
|
||||
impl From<std::io::Error> for KvError {
|
||||
fn from(err: std::io::Error) -> Self {
|
||||
KvError::IOError(err.to_string())
|
||||
|
Loading…
Reference in New Issue
Block a user