Skip to content

Sequent cryptographic library for use in secure online voting protocols.

License

Notifications You must be signed in to change notification settings

sequentech/strand

Repository files navigation

strand

Chat Build Status codecov Dependency status License REUSE

Strand is a cryptographic library for use in secure online voting protocols.

Primitives

The following primitives are implemented

Shuffle proofs have been independently verified

Group backends

The library supports pluggable discrete log backends, there are currently three:

Significant dependencies

Continuous Integration

There are multiple checks executed through the usage of Github Actions to verify the health of the code when pushed:

  1. Compiler warning/errors: checked using cargo check and cargo check ---tests. Use cargo fix and cargo fix --tests to fix the issues that appear.
  2. Unit tests: check that all unit tests pass using cargo test.
  3. Code style: check that the code style follows standard Rust format, using cargo fmt -- --check. Fix it using cargo fmt.
  4. Code linting: Lint that checks for common Rust mistakes using cargo clippy. You can try to fix automatically most of those mistakes using cargo clippy --fix -Z unstable-options.
  5. Code coverage: Detects code coverage with cargo-tarpaulin and pushes the information (in master branch) to codecov.
  6. License compliance: Check using REUSE for license compliance within the project, verifying that every file is REUSE-compliant and thus has a copyright notice header. Try fixing it with reuse lint.
  7. Dependencies scan: Audit dependencies for security vulnerabilities in the RustSec Advisory Database, unmaintained dependencies, incompatible licenses and banned packages using cargo-deny. Use cargo deny fix or cargo deny --allow-incompatible to try to solve the detected issues. We also have configured dependabot to notify and create PRs on version updates.
  8. Benchmark performance: Check benchmark performance and alert on regressions using cargo bench and github-action-benchmark.
  9. CLA compliance: Check that all committers have signed the Contributor License Agreement using CLA Assistant bot.
  10. Browser testing: Check the library works on different browsers and operating systems using browserstack. Run npm run local on the browserstack folder to try it locally. You'll need to configure the env variables GIT_COMMIT_SHA, BROWSERSTACK_USERNAME, BROWSERSTACK_ACCESS_KEY.

Development environment

Strand uses Github dev containers to facilitate development. To start developing strand, clone the github repo locally, and open the folder in Visual Studio Code in a container. This will configure the same environment that strand developers use, including installing required packages and VS Code plugins.

We've tested this dev container for Linux x86_64 and Mac Os arch64 architectures. Unfortunately at the moment it doesn't work with Github Codespaces as nix doesn't work on Github Codespaces yet. Also the current dev container configuration for strand doesn't allow commiting to the git repo from the dev container, you should use git on a local terminal.

Nix reproducible builds

strand uses the Nix Package Manager as its package builder. To build strand, first install Nix correctly in your system. If you're running the project on a dev container, you shouldn't need to install it.

After you have installed Nix, enter the development environment with:

nix develop

Updating Cargo.toml

Use the following cargo-edit command to upgrade dependencies to latest available version. This can be done within the nix develop environment:

cargo upgrade -Z preserve-precision

This repository doesn´t include a Cargo.lock file as it is intended to work as a library. However for Wasm tests we keep a copy of the file on Cargo.lock.copy. If you update Cargo.toml, keep the lock copy file in sync by generating the lock file with cargo generate-lockfile, then mv Cargo.lock Cargo.lock.copy and commit the changes.

building

This project uses nix to create reproducible builds. In order to build the project as a library for the host system, run:

nix build

You can build the project as a WASM library with:

nix build .#strand-wasm

If you don't want to use nix, you can build the project with:

cargo build

Build with parallelism

Uses rayon's parallel collections for compute intensive operations

cargo build --features=rayon

unit tests

cargo test

wasm test

See here.

benchmarks

See here.