Skip to content
/ SaUCy Public

The modular protocol framework based on Universal Composability

License

Notifications You must be signed in to change notification settings

initc3/SaUCy

Repository files navigation

SaUCy Build Status

The Super amazing Universal Composability (SaUCy) framework aims to make universal composability a practical tool for modular development of security protocols.

This repository includes a Haskell implementation of the Interactive Lambda Calculus (ILC), a newly designed process calculus that faithfully captures the computational model underlying UC: interactive Turing machines (ITMs). ILC adapts ITMs to a subset of the π-calculus through an affine typing discipline. That is, well-typed ILC programs are expressible in ITMs. In turn, ILC's strong confluence property enables reasoning about cryptographic security reductions. We also use ILC to build a concrete, executable (preliminary) implementation of the UC framework.

More details about ILC and SaUCy can be found in our paper.

This repository is still work in progress. Stay tuned for more details.

Installation

  1. Install Haskell platform.
  2. Run stack build.

Running ILC Programs

The ILC implementation includes an interactive environment, in which ILC expressions can be interactively evaluated and programs can be interpreted. You can fire up the interactive environment with the command stack exec -- saucy.

Here's a summary of commands available:

Command Description
:load <FILE> Load ILC source file
:browse List all variables in scope with their type signatures
:type <EXPR> Print type of ILC expression
:quit Quit

ILC source files can also be executed with the command stack exec -- saucy <FILE>.

About

The modular protocol framework based on Universal Composability

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •