MASC (Mutation Analysis for Evaluating Static Crypto-API Misuse Detectors) is a framework for systematic and data-driven evaluation of static analysis based crypto-API misuse detectors (Crypto-detectors). MASC does this by (1) using realistic, expressive crypto-API specific mutation-operators to create expressions of crypto API misuse (misuse instances), (2) creating mutant apps by injecting misuse instances in open source Java or Android applications, and (3) evaluating crypto-detectors by analyzing the reports produced from scanning the mutated apps.
For a more detailed explanation of the concepts behind MASC and a step-by-step guide to its features, check out this video demonstration.
MASC is built to run using Java LTS version 11. Please refer to your operating system specific instructions (e.g., Oracle) to install Java. Please make sure that it is available in the system PATH
, and can be accessed from terminal. For example, running java -version
in terminal/cmd should show a message similar to the following:
java -version
openjdk version "11.0.19" 2023-04-18 LTS
OpenJDK Runtime Environment Corretto-11.0.19.7.1 (build 11.0.19+7-LTS)
OpenJDK 64-Bit Server VM Corretto-11.0.19.7.1 (build 11.0.19+7-LTS, mixed mode)
Moreover, MASC needs gradle to be built. Please refer to your OS specific instructions to install gradle.
To get started, we need to do the following:
- Start by cloning the MASC Repository from GitHub.
- a) Open the cloned repository, go to
masc-core
directory, and rungradlew shadowJar
to create a JAR file for MASC. The output JAR can be found atmasc-core > app > build > libs > masc-<version>.jar
. The current version is 2.0. b) alternatively, you can use gradle to build MASC (you may have to assign execution permission to gradlew)cd masc-core ./gradlew build
- Test run with
java -jar masc-2.0.jar
. If you see the message "No configuration file provided", it means MASC has been successfully built and can be provided a configuration file.
MASC is run by specifying the parameters in a text-based configuration (*.properties
) file consisting of multiple key = value
pairs separated by new-lines. Some of the keys are required, whereas the others are optional. Since there can be several combination keys, we will use the following simple configuration file to get you familiarized with MASC.
mutantGeneration = true
type = StringOperator
outputDir = app/outputs
scope = MAIN
className = CryptoTest
apiName = javax.crypto.Cipher
invocation = getInstance
secureParam = AES/GCM/NoPadding
insecureParam = AES
noise = ~
variableName = cryptoVariable
Here, the first six keys are required. Note that the order of the keys in the configuration file does not matter.
For more examples of configuration files, go here.
We also have a detailed guide on writing configuration files and with explanation of each key = value
pairs in the user manual.
MASC can be run using both Command Line Interface and Browser-based User Interface, which we discuss next.
MASC web interface provides a user the opportunity to explore MASC along with its various scopes and operators. The web interface shall give the user the privilege to run Masc lab and Masc engine. Using MASC Lab a user can inspect the functionality of different operators for different configurations and through MASC Engine they can mutate their source code using both Exhaustive or Selective Scope.
The project is based on django frame work.
python => 3.10.4
Django => (4, 0, 5, 'final', 0)
The MASC web interface is available in the masc-web-django
branch of MASC Repository from GitHub. To get started, please clone the masc-web-django
branch.
Next, create virtual environment to setup project specific dependencies. For example,
python3 -m venv venv
source venv/bin/activate
for windows
python3 -m venv venv
.\venv\Scripts\activate
Next, install Dependencies,
pip install -r requirements.txt
and make the necessary databases and files:
python manage.py makemigrations
python manage.py migrate
Finally, run server
python manage.py runserver
For the user manual of MASC web interface please go here
In the example configuration file, we have specified that we want to create crypto-API misuse instances in a bare-bone Java source file that contains a main
method. Due to the bare-bone nature, MASC does not need an input app to mutate, rather it creates a single source code file and then introduces the misuse instance inside it for convenience.
Assuming that the above sample configuration file is saved in a file called Cipher.properties
, please run the following:
java -jar masc.jar Cipher.properties
Check the output folder (as specified in the configuration file). You will find n
folders, each containing the output of an operator, which is a mutated application. Now, you can analyze these mutants by static analyzers of your choice manually or by using the automated analysis module of MASC as described here.
Both exhaustive and similarity scopes of MASC depends on lib4ast directory. Therefore, you need to provide the absolute path to the lib4ast directory when configuring MASC. Further details below.
The Exhaustive Scope (extended on mSE) exhaustively seeds mutants at all locations in the target app's code allowed by Java syntax rules, i.e., class definitions, conditional segments, method bodies as well as anonymous inner class object declarations. Here is a sample configuration file for using exhaustive scope.
appSrc = <app source directory>
appName = <name of app>
outputDir = <output directory>
scope = EXHAUSTIVE
lib4ast = <path to lib4ast>
The Similarity Scope (extended on MDROID+) uses an abstract syntax tree to seed instances of misuse cases at locations in a target application’s source code where a similar API is already being used, i.e., akin to modifying existing API usages and making them vulnerable. For a configuration file, simply changing the scope from "EXHAUSTIVE" to "SIMILARITY" will suffice.
MASC's automated analysis module automatically compiles mutated apps produced from the main scope, tests them using chosen Crypto-detectors, then identifies the killed and unkilled mutants. Although this feature is currently limited to Crypto-detectors that can output in the SARIF format, MASC's automated analysis now supports CogniCrypt even though it uses a custom format instead of SARIF.
To run automated analysis, add the following to your properties file and run normally:
automatedAnalysis = true
toolName = find-sec-bugs
toolLocation = /home/yusuf/Downloads
toolRunCommand = bash findsecbugs.sh -high -sarif -output out.json {}
mutatedAppsLocation = app/outputs
codeCompileCommand = javac *.java
outputReportDirectory = /home/yusuf/Downloads
outputFileName = out.json
stopCondition = OnError
To run automated analysis only without mutant generation, add this line to the properties file:
mutantGeneration = false
If you want to run MASC's automated analysis for CogniCrypt, just add an extra field -
wrapper = CogniCrypt
You can write your own operators as plugins for MASC for the main scope.
Programmatically, you can create plugins by extending five existing restrictive-type operators of MASC. Furthermore, you can also create your own plugin that need not depend on any of the existing operators.
For a detailed guide on writing your own plugins, check the user manual here.
To write your own operators as plugins, these are the general steps you will need to follow:
- Write the code in a .java file
- Compile the code to get the .class file
- Place the .class file in /plugins/
- Run the jar normally
- Find the generated mutated apps in /app/outputs
Here, we provide details related to each of the steps:
Here is a sample code creating a plugin based on the StringOperator of MASC:
package plugins;
import edu.wm.cs.masc.mutation.operators.restrictive.stringoperator.AStringOperator;
import edu.wm.cs.masc.mutation.properties.StringOperatorProperties;
public class MyStrOperatorPlugin extends AStringOperator {
public MyStrOperatorPlugin(StringOperatorProperties properties) {
super(properties);
}
@Override
public String mutation() {
// insert your code to generate the mutation here
// here is a simple example
// return "javax.crypto.Cipher.getInstance(\"aes\");";
// here is a more realistic example
StringBuilder s = new StringBuilder();
s.append(api_name)
.append(".")
.append(invocation)
.append("(\"")
.append(insecureParam.toLowerCase())
.append("\");");
return s.toString();
}
}
For more sample codes for plugins of different types, please visit the plugin documentation.
Next, you can compile the code using the binary of MASC. Open a command prompt in folder where your code for the plugin is, and run this command:
javac -cp directory/masc-<version>.jar *.java
Place the .class
files in /plugins/ folder.
Run the jar as usual.
java -jar MASC.jar configuration-file.properties
Generated mutated apps will be produces in app/output/
Output from plugins will have plugins.
prefixed in their names.
If you use MASC, please cite the following two papers:
A. S. Ami, N. Cooper, K. Kafle, K. Moran, D. Poshyvanyk and A. Nadkarni, "Why Crypto-detectors Fail: A Systematic Evaluation of Cryptographic Misuse Detection Techniques," 2022 IEEE Symposium on Security and Privacy (SP), San Francisco, CA, USA, 2022, pp. 614-631, doi: 10.1109/SP46214.2022.9833582.
@inproceedings{ami-masc-oakland22,
author = {Ami, {Amit Seal} and Cooper, Nathan and Kafle, Kaushal and Moran, Kevin and Poshyvanyk, Denys and Nadkarni, Adwait},
booktitle = {2022 IEEE Symposium on Security and Privacy (S\&P)},
title = {{Why Crypto-detectors Fail: A Systematic Evaluation of Cryptographic Misuse Detection Techniques}},
year = {2022},
address = {San Francisco, CA, USA},
month = may,
pages = {397--414},
publisher = {IEEE Computer Society},
issn = {2375-1207},
pdf = {https://amitsealami.com/publications/ami-oakland22.pdf},
url = {https://ieeexplore.ieee.org/document/9833582},
doi = {10.1109/SP46214.2022.9833582},
month_numeric = {5}
}
Amit Seal Ami, Syed Yusuf Ahmed, Radowan Mahmud Redoy, Nathan Cooper, Kaushal Kafle, Kevin Moran, Denys Poshyvanyk, and Adwait Nadkarni. 2023. MASC: A Tool for Mutation-Based Evaluation of Static Crypto-API Misuse Detectors. In Proceedings of the 31st ACM Joint European Software Engineering Conference and Symposium on the Foundations of Software Engineering (ESEC/FSE ’23), December 3–9, 2023, San Francisco, CA, USA. ACM, New York, NY, USA, 5 pages. https://doi.org/10.1145/3611643.3613099
@inproceedings{asr-masc-demo,
author = {Ami, Amit Seal and Ahmed, Syed Yusuf and Redoy, Radowan Mahmud and Cooper, Nathan and Kafle, Kaushal and Moran, Kevin and Poshyvanyk, Denys and Nadkarni, Adwait},
title = {{MASC: A Tool for Mutation-based Evaluation of Static Crypto-API Misuse Detectors}},
booktitle = {Proceedings of the ACM Joint European Software Engineering Conference and Symposium on the Foundations of Software Engineering (ESEC/FSE'23), Demonstration Track},
year = {2023},
doi = {10.1145/3611643.3613099},
pdf = {https://amitsealami.com/publications/ami-masc-demo-fse23.pdf},
address = {San Francisco},
month = dec,
note = {to be published in},
month_numeric = {12}
}
To access the user manuals and High Level Architectural diagrams, please go here.
Development of MASC has been supported in part by the NSF-1815336, NSF1815186 and NSF-1955853 grants; as well as COVA CCI Cybersecurity Dissertation Fellowship.
MASC has truly been built on the shoulders of open source projects that come from both industry and academia. In particular,
- the similarity scope is built using the MDROID+ framework
- the exhaustive scope is built using the mSE framework
- JavaPoet for generating the mutated crypto-API misuse instances to some extent
- Eclipse JDT, AST, and more
- Apache Commmons, and many more.