Skip to content

gmawdo/graymamba

Repository files navigation

A Highly Secure Provenance Tracking Filesystem

  • A secure filesystem that intrinsically tracks the provenance of files and directories.
  • Entirely written in Rust for memory safety and performance.
  • Supporting "Secure by Design" approach as articulated by gov CISA Secure by Design and with reference to aspects of the SSDF by NIST SP 800-218 extending to principles of "capabilities" and memory safety as per Cheri
  • Built on an NFS protocol layer and very loosely seeded with NFSServe, promoting ease of integration into existing systems and workflows. We restructured the NFSServe core under our src/kernel.
  • Can be utilised in both local and distributed environments, with the ability to scale out to multiple nodes.
  • Deployable to Mac and Linux devices (Windows if you must)
  • Useful for secure capture and data transmission in the IoT space.
  • Useful for secure collaboration and data sharing in sensitive environments.
  • Can be used as a secure data store for AI models and data.
  • Can be used to underpin many aspects of a "Secure by Design" approach.
  • Can be backed by a variety of data stores, including RocksDB, Redis, and we'd like to add Cassandra in the future. We are really interested in the ability to use a distributed database for the backing store.
  • Used in conjunction with Eclipse-Theia and Kubernetes to provide a secure traceable IDE at scale for Codasip's cloud based RISC-V chip design toolchain.
  • Now also tested with vscode server based IDE leveraging Kubernetes resource management from the Theia project.

Overview

Building

Features (determines what is built into the binary)

  • Mandatory Backing Store, choose one of [ rocksdb_store | redis_store ]: Enables RocksDB or Redis as backing store for data shares (one of the two options must be chosen)
  • Mandatory irrefutable_audit, choose one of [ merkle_audit | az_audit ]: Enables irrefutable audit logs for files and directories. Merkle audit writes to a merkle tree in a RocksDB, AZ audit writes to Aleph Zero custom blockchain.
  • Optional compressed_store: Enables compressed shares (if not specified then works uncompresed with reduced performance but greater traceability

RocksDB is built-in to the filesystem if chosen. If Redis is the store of choice, then it will need to be installed and running on the machine.

Build and Run Commands

  • To run or test the filesystem: 🚀

    cargo build --bin graymamba --features="merkle_audit,compressed_store,rocksdb_store" --release
    cargo run --bin graymamba --features="merkle_audit,compressed_store,rocksdb_store" --release
    cargo test --features merkle_audit -- --nocapture
    

    --features="merkle_audit,compressed_store,rocksdb_store" is the default feature set

  • To build and run the audit_reader, qrocks, and data-room (see below for more details on these binaries): 🚀

    cargo run --bin audit_reader --release (this is only for use with the merkle audit option currently)
    cargo run --bin qrocks --release
    cargo run --bin data-room --release
    
  • To run the Linter : 🚀

    cargo clippy --features="merkle_audit,compressed_store"
    
  • To run bench marking : 🚀

     cargo bench --features="merkle_audit,compressed_store"
    
  • To enable metrics : 🚀

     cargo run --bin graymamba --features="metrics"
      metrics server runs on localhost:9091, configure the Prometheus server to scrape metrics from this address
    

Explanation of the project's binaries and their purpose

  • graymamba: The filesystem itself, which can be mounted as an NFS server. The main man.
  • audit_reader: Reads the audit logs and allows exploration, verification and proof generation.
  • qrocks: A tool for querying the RocksDB database as there seems not to be one in wide circulation
  • data-room: An experimental tool for providing a data sandbox for file sharing and collaboration in sensitive environments.

Logging and Tracing

The project uses a sophisticated logging system based on tracing and tracing_subscriber that provides structured, contextual logging with runtime configuration.

Configuration

  • Primary: config/settings.toml for base configuration
  • Secondary: Environment variables for runtime overrides
  • Default Level: "warn" if not explicitly configured

Example Configuration

toml [logging] level = "info" # Base logging level module_filter = [ "graymamba::sharesfs::channel_buffer=debug", "graymamba::sharesfs::writing=debug", "graymamba::sharesfs::directories=debug", "graymamba::sharesfs::rename=debug", #"graymamba::kernel=debug", "graymamba::kernel::vfs::api=debug", #"data_room=debug", "graymamba::backingstore::rocksdb_data_store=debug" ]

Features

  • Structured Logging: Maintains context across async boundaries
  • Zero-Cost Abstractions: Disabled log levels have no runtime overhead
  • Flexible Output:
    • Log level
    • Source file and line numbers
    • Compact formatting
    • Writes to stderr for container compatibility
  • Runtime Filtering: Adjust log levels without recompilation
  • Module-Level Control: Fine-grained logging for different components

Usage in Code

rust // Examples of usage in our code tracing::info!("Operation started"); tracing::debug!("Detailed info: {:?}", data); tracing::error!("Error occurred: {}", error);

Architecture

Uses the Observer pattern through subscribers and layers:

  1. Application code emits events
  2. Events pass through configurable filters
  3. Subscribers process and format events
  4. Output is written to configured destination (stderr)

This approach provides robust logging suitable for both development and production environments, with the flexibility to adapt to different deployment scenarios.

Useful references

Configure a Redis Cluster:

  Set up a Redis Cluster with 3 node with ports 6380,6381,6382.
   - Install Redis : https://redis.io/docs/latest/operate/oss_and_stack/install/install-redis/

- This will require a config file for each node: e.g. redis-6380.conf, redis-6381.conf, redis-6382.conf of the format:

                    # Change port 
                    port 6380 
                    #Expose the port
                    bind 0.0.0.0
                    #Mode
                    protected-mode no
                    # Data directory location
                    dir ./Redis_database/redis-6380
                    # Enable clustering  
                    cluster-enabled yes
                    # Set Password
                    requirepass password
                                 
                                              
         redis-cli --cluster create 127.0.0.1:6380 127.0.0.1:6381 127.0.0.1:6382 --cluster-replicas 0 -a password --cluster-yes

         nohup redis-server redis-6380.conf > redis0.log 2>&1 &
         nohup redis-server redis-6381.conf > redis1.log 2>&1 &
         nohup redis-server redis-6382.conf > redis2.log 2>&1 &

Configure Blockchain Node: (if using Polkadot/Aleph Zero for irrfutable audit)

  Set up a Polkadot/Aleph Zero node following below steps
  $ git clone https://github.com/datasignals/aleph-node-pinkscorpion.git (based on aleph-zero fork)
  $ cd aleph-node-pinkscorpion
  $ cargo build —release
  $ scripts/run_nodes.sh

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages