1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
// Copyright (C) 2019-2023 Aleo Systems Inc.
// This file is part of the snarkVM library.
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at:
// http://www.apache.org/licenses/LICENSE-2.0
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
use crate::FinalizeOperation;
use console::{
network::Network,
prelude::Result,
program::{Identifier, Plaintext, ProgramID, Value},
};
pub trait FinalizeStoreTrait<N: Network> {
/// Returns `true` if the given `program ID` and `mapping name` exist.
fn contains_mapping_confirmed(&self, program_id: &ProgramID<N>, mapping_name: &Identifier<N>) -> Result<bool>;
/// Returns `true` if the given `program ID`, `mapping name`, and `key` exist.
fn contains_key_speculative(
&self,
program_id: ProgramID<N>,
mapping_name: Identifier<N>,
key: &Plaintext<N>,
) -> Result<bool>;
/// Returns the speculative value for the given `program ID`, `mapping name`, and `key`.
fn get_value_speculative(
&self,
program_id: ProgramID<N>,
mapping_name: Identifier<N>,
key: &Plaintext<N>,
) -> Result<Option<Value<N>>>;
/// Stores the given `(key, value)` pair at the given `program ID` and `mapping name` in storage.
/// If the `mapping name` is not initialized, an error is returned.
/// If the `key` already exists, the method returns an error.
fn insert_key_value(
&self,
program_id: ProgramID<N>,
mapping_name: Identifier<N>,
key: Plaintext<N>,
value: Value<N>,
) -> Result<FinalizeOperation<N>>;
/// Stores the given `(key, value)` pair at the given `program ID` and `mapping name` in storage.
/// If the `mapping name` is not initialized, an error is returned.
/// If the `key` does not exist, the `(key, value)` pair is initialized.
/// If the `key` already exists, the `value` is overwritten.
fn update_key_value(
&self,
program_id: ProgramID<N>,
mapping_name: Identifier<N>,
key: Plaintext<N>,
value: Value<N>,
) -> Result<FinalizeOperation<N>>;
/// Removes the key-value pair for the given `program ID`, `mapping name`, and `key` from storage.
/// If the `key` does not exist, the method returns `None`.
fn remove_key_value(
&self,
program_id: ProgramID<N>,
mapping_name: Identifier<N>,
key: &Plaintext<N>,
) -> Result<Option<FinalizeOperation<N>>>;
}