10: Create ExternalStoragePlugin
This commit is contained in:
@@ -1,6 +1,7 @@
|
|||||||
package com.bartek.esa.core.di;
|
package com.bartek.esa.core.di;
|
||||||
|
|
||||||
import com.bartek.esa.core.archetype.Plugin;
|
import com.bartek.esa.core.archetype.Plugin;
|
||||||
|
import com.bartek.esa.core.helper.ParentNodeFinder;
|
||||||
import com.bartek.esa.core.helper.StaticScopeHelper;
|
import com.bartek.esa.core.helper.StaticScopeHelper;
|
||||||
import com.bartek.esa.core.java.JavaSyntaxRegexProvider;
|
import com.bartek.esa.core.java.JavaSyntaxRegexProvider;
|
||||||
import com.bartek.esa.core.plugin.*;
|
import com.bartek.esa.core.plugin.*;
|
||||||
@@ -82,4 +83,10 @@ public class PluginModule {
|
|||||||
public Plugin strictModePlugin(GlobMatcher globMatcher, XmlHelper xmlHelper, StaticScopeHelper staticScopeHelper) {
|
public Plugin strictModePlugin(GlobMatcher globMatcher, XmlHelper xmlHelper, StaticScopeHelper staticScopeHelper) {
|
||||||
return new StrictModePlugin(globMatcher, xmlHelper, staticScopeHelper);
|
return new StrictModePlugin(globMatcher, xmlHelper, staticScopeHelper);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Provides
|
||||||
|
@IntoSet
|
||||||
|
public Plugin externalStoragePlugin(GlobMatcher globMatcher, XmlHelper xmlHelper, ParentNodeFinder parentNodeFinder) {
|
||||||
|
return new ExternalStoragePlugin(globMatcher, xmlHelper, parentNodeFinder);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,44 @@
|
|||||||
|
package com.bartek.esa.core.plugin;
|
||||||
|
|
||||||
|
import com.bartek.esa.core.archetype.JavaPlugin;
|
||||||
|
import com.bartek.esa.core.helper.ParentNodeFinder;
|
||||||
|
import com.bartek.esa.core.model.enumeration.Severity;
|
||||||
|
import com.bartek.esa.core.xml.XmlHelper;
|
||||||
|
import com.bartek.esa.file.matcher.GlobMatcher;
|
||||||
|
import com.github.javaparser.ast.CompilationUnit;
|
||||||
|
import com.github.javaparser.ast.body.MethodDeclaration;
|
||||||
|
import com.github.javaparser.ast.expr.MethodCallExpr;
|
||||||
|
|
||||||
|
import javax.inject.Inject;
|
||||||
|
|
||||||
|
public class ExternalStoragePlugin extends JavaPlugin {
|
||||||
|
private final ParentNodeFinder parentNodeFinder;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
public ExternalStoragePlugin(GlobMatcher globMatcher, XmlHelper xmlHelper, ParentNodeFinder parentNodeFinder) {
|
||||||
|
super(globMatcher, xmlHelper);
|
||||||
|
this.parentNodeFinder = parentNodeFinder;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void run(CompilationUnit compilationUnit) {
|
||||||
|
compilationUnit.findAll(MethodCallExpr.class).stream()
|
||||||
|
.filter(expr -> expr.getName().getIdentifier().matches("getExternalStorageDirectory|getExternalStoragePublicDirectory"))
|
||||||
|
.forEach(this::findCheckingStorageStateForAccessingExternalStorage);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void findCheckingStorageStateForAccessingExternalStorage(MethodCallExpr accessingToExternalStorage) {
|
||||||
|
parentNodeFinder.findParentNode(accessingToExternalStorage, MethodDeclaration.class).ifPresent(methodDeclaration ->
|
||||||
|
findCheckingStorageStateInMethodDeclaration(accessingToExternalStorage, methodDeclaration)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void findCheckingStorageStateInMethodDeclaration(MethodCallExpr accessingToExternalStorage, MethodDeclaration methodDeclaration) {
|
||||||
|
boolean isStateBeingChecked = methodDeclaration.findAll(MethodCallExpr.class).stream()
|
||||||
|
.anyMatch(e -> e.getName().getIdentifier().equals("getExternalStorageState"));
|
||||||
|
|
||||||
|
if (!isStateBeingChecked) {
|
||||||
|
addIssue(Severity.WARNING, getLineNumberFromExpression(accessingToExternalStorage), accessingToExternalStorage.toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -79,3 +79,7 @@ com.bartek.esa.core.plugin.CipherInstancePlugin=Not fully-qualified algorithm na
|
|||||||
|
|
||||||
com.bartek.esa.core.plugin.StrictModePlugin=Strict mode is turned on.\n\
|
com.bartek.esa.core.plugin.StrictModePlugin=Strict mode is turned on.\n\
|
||||||
Strict mode was found in the file. Remember to delete it before publishing.
|
Strict mode was found in the file. Remember to delete it before publishing.
|
||||||
|
|
||||||
|
com.bartek.esa.core.plugin.ExternalStoragePlugin=External storage state is not checked.\n\
|
||||||
|
There is attempt to access to external storage without checking its state.\n\
|
||||||
|
External storage state should be checked through 'Environment.getExternalStorageState()' method.
|
||||||
Reference in New Issue
Block a user