Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 0 additions & 2 deletions .idea/compiler.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

5 changes: 5 additions & 0 deletions .idea/jarRepositories.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

11 changes: 11 additions & 0 deletions .idea/misc.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 0 additions & 3 deletions .idea/modules.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

9 changes: 7 additions & 2 deletions build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,13 @@ plugins {
id 'java'
id 'org.jetbrains.intellij' version '0.4.10'
id 'maven'
id 'org.jetbrains.kotlin.jvm' version '1.3.72'
}

apply plugin: 'idea'
apply plugin: 'org.jetbrains.intellij'
apply plugin: 'java'
apply plugin: "kotlin"

group 'de.fraunhofer'
version '0.2.5.1'
Expand All @@ -21,6 +23,7 @@ repositories {
}

dependencies {
implementation("org.jetbrains.kotlin:kotlin-stdlib-jdk8:1.3.72")
testCompile group: 'junit', name: 'junit', version: '4.12'
compile group: 'ca.mcgill.sable', name: 'soot', version: '4.0.0'
compile group: 'de.fraunhofer.iem', name: 'CryptoAnalysis-Android', version: '2.7.2-SNAPSHOT'
Expand All @@ -29,11 +32,13 @@ dependencies {
compile group: 'de.tud.sse', name: 'soot-infoflow-android', version: '2.7.1'
compile group: 'de.tud.sse', name: 'soot-infoflow-cmd', version: '2.7.1'
compile group: 'org.swinglabs.swingx', name: 'swingx-all', version: '1.6.4'


}

// See https://github.com/JetBrains/gradle-intellij-plugin/gradle
intellij {
plugins 'android', 'java', 'maven', 'gradle'
plugins 'android', 'java', 'maven', 'gradle', 'Kotlin'
//version '2019.2.2'
updateSinceUntilBuild false

Expand All @@ -58,7 +63,7 @@ runIde {

patchPluginXml {
sinceBuild '191'
untilBuild '201.*'
untilBuild '202.*'
changeNotes """
Add change notes here.<br>
<em>most HTML tags may be used</em>"""
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ public class RunCogniCryptAction extends CogniCryptAction implements DumbAware
private static final Logger logger = Logger.getInstance(RunCogniCryptAction.class);
private final IPersistableCogniCryptSettings _settings;
private final IdeType _ideType;
public static boolean EnabledFlag= true;

public RunCogniCryptAction()
{
Expand All @@ -49,6 +50,12 @@ public void actionPerformed(@NotNull AnActionEvent e)
Iterable<File> files = GetFilesToAnalyze(project);

// TODO: Re-Enable
if(e.getPresentation().isEnabled()){
e.getPresentation().setEnabled(false);
EnabledFlag=false;
update(e);
}

/*
if (files == null || !Linq.any(files))
{
Expand Down Expand Up @@ -87,6 +94,14 @@ private Iterable<File> GetFilesToAnalyze(Project project)
}
return Collections.EMPTY_LIST;
}
public static void SetFlag(boolean b){
EnabledFlag=b;
}
@Override
public void update(AnActionEvent e) {
e.getPresentation().setEnabled(EnabledFlag);
}

}


Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
import crypto.interfaces.ISLConstraint;
import crypto.rules.CrySLPredicate;
import de.fraunhofer.iem.icognicrypt.Constants;
import de.fraunhofer.iem.icognicrypt.actions.RunCogniCryptAction;
import de.fraunhofer.iem.icognicrypt.core.Language.JvmClassNameUtils;
import de.fraunhofer.iem.icognicrypt.results.CogniCryptError;
import de.fraunhofer.iem.icognicrypt.results.IResultProvider;
Expand All @@ -29,7 +30,6 @@
import soot.SootClass;
import sync.pds.solver.nodes.Node;
import typestate.TransitionFunction;

import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
Expand All @@ -43,6 +43,7 @@ class AnalysisListenerService extends CrySLAnalysisListener implements Disposabl
private static final Logger logger = LoggerFactory.getLogger(AnalysisListenerService.class);
private final Project _project;
private IResultProvider _resultProvider;
public static boolean EnabledFlag;

private final List<String> _sourceCodeFiles;

Expand All @@ -54,6 +55,7 @@ private AnalysisListenerService(Project project, IResultProvider resultProvider)

@Override
public void beforeAnalysis() {
EnabledFlag= false;
_resultProvider.RemoveAllResults();
_sourceCodeFiles.clear();

Expand All @@ -66,6 +68,7 @@ public void afterAnalysis() {
//After analysis completes, restart code analyzer so that error markers can be updated
//for (Project project : ProjectManager.getInstance().getOpenProjects())
DaemonCodeAnalyzer.getInstance(_project).restart();
RunCogniCryptAction.SetFlag(true);
}

@Override
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
import crypto.analysis.errors.IncompleteOperationError;
import de.fraunhofer.iem.crypto.CogniCryptAndroidAnalysis;
import de.fraunhofer.iem.icognicrypt.Constants;
import de.fraunhofer.iem.icognicrypt.actions.RunCogniCryptAction;
import de.fraunhofer.iem.icognicrypt.core.Language.JvmClassNameUtils;
import de.fraunhofer.iem.icognicrypt.results.CogniCryptError;
import de.fraunhofer.iem.icognicrypt.results.IResultProvider;
Expand Down Expand Up @@ -111,6 +112,7 @@ public void onFinished()
_analysisQueue = null;
_stopWatch = null;
_resultProvider = null;
RunCogniCryptAction.SetFlag(true);
}

@Override
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -86,8 +86,8 @@ public static void RunIntelliJAnalysis(Project project, Iterable<File> filesToAn
Task analysis = new JavaProjectAnalysisTask(modulePath, Joiner.on(File.pathSeparator).join(classpath),
settings.getRulesDirectory());
ProgressManager.getInstance().run(analysis);

*/

}

ProgressManager.getInstance().run(new JavaProjectAnalysisTask(project, modulePaths
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -47,12 +47,12 @@ public LineMarkerInfo getLineMarkerInfo(@NotNull PsiElement psiElement)
}
return null;
}

/*
@Override
public void collectSlowLineMarkers(@NotNull List<PsiElement> list, @NotNull Collection<LineMarkerInfo> collection) {
int i = 0;
}

*/
private LineMarkerInfo CreateNewMarker(PsiElement psiElement, Iterable<CogniCryptError> errors){
return new LineMarkerInfo<>(psiElement, psiElement.getTextRange(), PluginIcons.ERROR, Pass.LINE_MARKERS,
new TooltipProvider(getErrorsMessage(errors)), null, GutterIconRenderer.Alignment.LEFT);
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
package de.fraunhofer.iem.icognicrypt.results;

import com.intellij.codeHighlighting.Pass;
import com.intellij.codeInsight.daemon.LineMarkerInfo;
import com.intellij.codeInsight.daemon.LineMarkerProvider;
import com.intellij.openapi.components.ServiceManager;
import com.intellij.openapi.editor.Document;
import com.intellij.openapi.editor.markup.GutterIconRenderer;
import com.intellij.openapi.project.Project;
import com.intellij.psi.*;
import com.intellij.psi.impl.source.tree.java.ClassElement;
import org.jetbrains.kotlin.psi.*;
import icons.PluginIcons;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import org.jetbrains.uast.UElement;
import org.jetbrains.uast.UElementKt;
import java.util.Set;

public class KotlinErrorLineMarker implements LineMarkerProvider
{
// TODO: Somehow this code is not executed with Kotlin files.
@Nullable
public LineMarkerInfo getLineMarkerInfo(@NotNull KtElement psiElement)
{
IResultProvider resultProvider = ServiceManager.getService(psiElement.getProject(), IResultProvider.class);
int lineNumber = getLineNumber(psiElement) + 1;

UElement uElement= (UElement) psiElement.getNode();
// PsiElement element= UElementKt.getAsJavaPsiElement((UElement) psiElement.getNode(),psiElement.getClass());
PsiElement element= uElement.getSourcePsi();
String path = psiElement.getContainingFile().getVirtualFile().getPath();
Set<CogniCryptError> errors = resultProvider.FindErrors(path, lineNumber);
if (!errors.isEmpty())
return CreateNewMarker(element, errors);

return null;
}
/*
@Override
public void collectSlowLineMarkers(@NotNull List<PsiElement> list, @NotNull Collection<LineMarkerInfo> collection) {
int i = 0;
}
*/
private LineMarkerInfo CreateNewMarker(PsiElement element, Iterable<CogniCryptError> errors){
return new LineMarkerInfo<>(element, element.getTextRange(), PluginIcons.ERROR, Pass.LINE_MARKERS,
new TooltipProvider(getErrorsMessage(errors)), null, GutterIconRenderer.Alignment.LEFT);
}

private String getErrorsMessage(Iterable<CogniCryptError> errors) {
String s = "";
for(CogniCryptError e : errors){
s += e.getErrorMessage() +"\n";
}
return s;
}

//Returns line number for PSI element
private int getLineNumber(KtElement psiElement) {
KtFile containingFile = (KtFile) psiElement.getContainingFile();
Project project = containingFile.getProject();
PsiDocumentManager psiDocumentManager = PsiDocumentManager.getInstance(project);
Document document = psiDocumentManager.getDocument(containingFile);
int textOffset = psiElement.getTextOffset();

return document.getLineNumber(textOffset);
}

private PsiClass FindClass(KtElement element){
if (element instanceof KtClass)
return (PsiClass) element;
if (element == null)
return null;
return FindClass((KtElement) element.getParent());
}

@Override
public LineMarkerInfo<?> getLineMarkerInfo(@NotNull PsiElement element) {
return null;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -39,14 +39,14 @@ public CogniCryptResultWindow(ToolWindow toolWindow, Project project)
IResultProvider service = ServiceManager.getService(project, IResultProvider.class);
service.Subscribe(_tableModel);


for (Set<CogniCryptError> errorSet : service.GetErrors().values())
{
for (CogniCryptError error : errorSet)
{
_tableModel.AddError(error);
}
}
// ToolWindow clearing when starting IDE
// for (Set<CogniCryptError> errorSet : service.GetErrors().values())
// {
// for (CogniCryptError error : errorSet)
// {
// _tableModel.AddError(error);
// }
// }
}

@Override
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ public void loadState(@NotNull CogniCryptSettingsPersistentComponent icognicrypt
}

@Override
public void setOptimizedLanguage(SupportedLanguage optimizedLanguage)
public void setOptimizedLanguage(@NotNull SupportedLanguage optimizedLanguage)
{
super.setOptimizedLanguage(optimizedLanguage);
ServiceManager.getService(SupportedLanguagesUtils.class).SupportedLanguages.Promote(optimizedLanguage);
Expand Down
Original file line number Diff line number Diff line change
@@ -1,11 +1,18 @@
package de.fraunhofer.iem.icognicrypt.ui;

import com.intellij.ide.DataManager;
import com.intellij.notification.Notification;
import com.intellij.notification.NotificationType;
import com.intellij.notification.Notifications;
import com.intellij.openapi.actionSystem.DataContext;
import com.intellij.openapi.actionSystem.PlatformDataKeys;
import com.intellij.openapi.project.Project;
import static de.fraunhofer.iem.icognicrypt.IdeSupport.projects.ProjectHelper.GetActiveProject;


public class NotificationProvider
{

public static void Warn(String message)
{
ShowNotification(message, NotificationType.WARNING);
Expand All @@ -24,6 +31,13 @@ public static void ShowError(String message)
private static void ShowNotification(String message, NotificationType type)
{
Notification notification = new Notification("CogniCrypt", "CogniCrypt Message", message, type);
Notifications.Bus.notify(notification);
Project project= GetActiveProject();
DataContext d = DataManager.getInstance().getDataContext();
Project project1= d.getData(PlatformDataKeys.PROJECT);
if(project==project1) {
Notifications.Bus.notify(notification, project);
}

}

}
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,9 @@
<children>
<component id="1c0ef" class="javax.swing.JList" binding="_filesListBox">
<constraints/>
<properties/>
<properties>
<model/>
</properties>
</component>
</children>
</scrollpane>
Expand Down
6 changes: 5 additions & 1 deletion src/main/resources/META-INF/plugin.xml
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,11 @@

<!-- please see http://www.jetbrains.org/intellij/sdk/docs/basics/getting_started/plugin_compatibility.html
on how to target different products -->
<depends>com.intellij.modules.platform</depends>
<depends>com.intellij.modules.java</depends>
<depends>org.jetbrains.android</depends>
<depends>org.jetbrains.kotlin</depends>
<depends optional="true" config-file="withKotlin.xml">org.jetbrains.kotlin</depends>

<!-- please see http://www.jetbrains.org/intellij/sdk/docs/basics/getting_started/build_number_ranges.html for description -->
<idea-version since-build="191.*"/>
Expand Down Expand Up @@ -46,8 +49,9 @@

<!-- Other Extensions -->
<extensions defaultExtensionNs="com.intellij">

<codeInsight.lineMarkerProvider language="JVM"
implementationClass="de.fraunhofer.iem.icognicrypt.results.CogniCryptErrorLineMarker"/>
implementationClass="de.fraunhofer.iem.icognicrypt.results.CogniCryptErrorLineMarker"/>

<applicationConfigurable instance="de.fraunhofer.iem.icognicrypt.settings.CogniCryptSettingsView" groupId="root"/>

Expand Down
Loading