forked from mitre/oldcpsa
-
Notifications
You must be signed in to change notification settings - Fork 0
Cryptographic Protocol Shapes Analyzer
License
mliskov/cpsa
Folders and files
| Name | Name | Last commit message | Last commit date | |
|---|---|---|---|---|
Repository files navigation
CPSA: Cryptographic Protocol Shapes Analyzer This program has been built and tested using Haskell Platform. It is available from <http://haskell.org> or from an operating system specific source. The name of the Linux package is usually haskell-platform. If the Internet is available, install CPSA with: $ cabal update $ cabal install cpsa Find the documentation directory by typing "cpsa -h" in a command shell, and view cpsamanual.pdf INSTALLING FROM A TARBALL QUICK START (Linux) : To build and install CPSA type: $ make $ make install : To analyze a protocol you have put in prob.scm type: $ cpsa -o prob.txt prob.scm $ cpsagraph -o prob.xhtml prob.txt $ firefox -remote "openFile(`pwd`/prob.xhtml)" : Documentation and samples are in the directory given by $ cpsa -h : To view the user guide: $ firefox -remote "openFile($HOME/share/cpsa-X.Y.Z/cpsamanual.pdf)" : where X.Y.Z is the CPSA version number. QUICK START (Mac) : To build and install CPSA type: $ make $ make install : To analyze a protocol you have put in prob.scm type: $ cpsa -o prob.txt prob.scm $ cpsagraph -o prob.xhtml prob.txt $ open prob.xhtml : Documentation and samples are in the directory given by $ cpsa -h : To view the user guide: $ open $HOME/share/cpsa-X.Y.Z/cpsamanual.pdf : where X.Y.Z is the CPSA version number. QUICK START (Windows) The software has been tested on a Windows system on which neither MinGW or Cygwin has been installed. Install GHC and then run the "setup.bat" batch file with administrator privileges. If you do not have administrator privileges, run: C:\...> runghc Setup.hs configure --user C:\...> runghc Setup.hs build The executables will be found in the dist\build subdirectories. Documentation and samples are in the directory given by C:\...> cpsa -h The installed programs can be run from the command prompt or via a batch file. Alternatively, copy Make.hs into the directory containing your CPSA problem statements, and load it into a Haskell interpreter. Read the source for usage instructions. MAKEFILE The file $HOME/share/cpsa-X.Y.Z/cpsa.mk contains useful GNU Make rules for inclusion, where X.Y.Z is CPSA version number. Alternatively, copy the file Make.hs in the same directory into the directory containing your CPSA problem statements. The source file has usage instructions. PARALLELISM CPSA is built so it can make use of multiple processors. To make use of more than one processor, start CPSA with a runtime flag that specifies the number of processors to be used, such as "+RTS -N4 -RTS". The GHC documentation describes the -N option in detail. TEST SUITE : To run the test suite type: $ ./cpsatst Tests with the .scm extension are expected to complete without error, tests with the .lsp extension are expected to fail, and tests with the .lisp extension are not run. New users should read tst/README, and then browse the files it suggests while reading CPSA documentation. Don't develop your protocols in the tst directory. The Makefile is optimized for testing the cpsa program, not analyzing protocols. ADDITIONAL PROGRAMS The src directory of the source distributions includes programs written in Scheme, Prolog, and Elisp for performing tasks. Use them as templates for your special purpose CPSA analysis and transformation needs. Also, when given the --json option, the CPSA pretty printer cpsapp will transform CPSA S-expressions into JavaScript Object Notation (JSON). On Linux, the GHC runtime can request so much memory that thrashing results. The script in src/ghcmemlimit sets an environment variable that limits memory to the amount of free and reclaimable memory on your machine. KNOWN BUGS Variable separation in generalization fails to separate variables in terms of the form (ltk a a).
About
Cryptographic Protocol Shapes Analyzer
Resources
License
Stars
Watchers
Forks
Releases
No releases published
Packages 0
No packages published
Languages
- Scilab 72.7%
- Haskell 22.4%
- Scheme 3.5%
- Prolog 0.9%
- Emacs Lisp 0.2%
- Common Lisp 0.1%
- Other 0.2%