Skip to content

Commit

Permalink
Added a warning about Security Manager deprecation and handle excepti…
Browse files Browse the repository at this point in the history
…on in Java 17+ (closes #286)
  • Loading branch information
keeganwitt committed Feb 26, 2024
1 parent ad71ea1 commit 60ad8a7
Show file tree
Hide file tree
Showing 3 changed files with 33 additions and 6 deletions.
13 changes: 11 additions & 2 deletions src/main/java/org/codehaus/gmavenplus/mojo/ConsoleMojo.java
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,12 @@ public void execute() throws MojoExecutionException, MojoFailureException {
final SecurityManager sm = System.getSecurityManager();
try {
if (!allowSystemExits) {
System.setSecurityManager(new NoExitSecurityManager());
getLog().warn("JEP 411 deprecated Security Manager in Java 17 for removal.");
try {
System.setSecurityManager(new NoExitSecurityManager());
} catch (UnsupportedOperationException e) {
getLog().warn("Attempted to use Security Manager in a JVM where it's disabled by default. You might try `-Djava.security.manager=disallow` to override this.");
}
}

// get classes we need with reflection
Expand Down Expand Up @@ -129,7 +134,11 @@ public void execute() throws MojoExecutionException, MojoFailureException {
throw new MojoExecutionException("Error occurred while instantiating a Groovy class from classpath.", e);
} finally {
if (!allowSystemExits) {
System.setSecurityManager(sm);
try {
System.setSecurityManager(new NoExitSecurityManager());
} catch (UnsupportedOperationException e) {
getLog().warn("Attempted to use Security Manager in a JVM where it's disabled by default. You might try `-Djava.security.manager=disallow` to override this.");
}
}
}
} else {
Expand Down
13 changes: 11 additions & 2 deletions src/main/java/org/codehaus/gmavenplus/mojo/ExecuteMojo.java
Original file line number Diff line number Diff line change
Expand Up @@ -140,7 +140,12 @@ protected synchronized void doExecute() throws MojoExecutionException {
final SecurityManager sm = System.getSecurityManager();
try {
if (!allowSystemExits) {
System.setSecurityManager(new NoExitSecurityManager());
getLog().warn("JEP 411 deprecated Security Manager in Java 17 for removal.");
try {
System.setSecurityManager(new NoExitSecurityManager());
} catch (UnsupportedOperationException e) {
getLog().warn("Attempted to use Security Manager in a JVM where it's disabled by default. You might try `-Djava.security.manager=disallow` to override this.");
}
}

// get classes we need with reflection
Expand All @@ -161,7 +166,11 @@ protected synchronized void doExecute() throws MojoExecutionException {
throw new MojoExecutionException("Unable to access a method on a Groovy class from classpath.", e);
} finally {
if (!allowSystemExits) {
System.setSecurityManager(sm);
try {
System.setSecurityManager(new NoExitSecurityManager());
} catch (UnsupportedOperationException e) {
getLog().warn("Attempted to use Security Manager in a JVM where it's disabled by default. You might try `-Djava.security.manager=disallow` to override this.");
}
}
}
} else {
Expand Down
13 changes: 11 additions & 2 deletions src/main/java/org/codehaus/gmavenplus/mojo/ShellMojo.java
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,12 @@ public void execute() throws MojoExecutionException {
final SecurityManager sm = System.getSecurityManager();
try {
if (!allowSystemExits) {
System.setSecurityManager(new NoExitSecurityManager());
getLog().warn("JEP 411 deprecated Security Manager in Java 17 for removal.");
try {
System.setSecurityManager(new NoExitSecurityManager());
} catch (UnsupportedOperationException e) {
getLog().warn("Attempted to use Security Manager in a JVM where it's disabled by default. You might try `-Djava.security.manager=disallow` to override this.");
}
}

// get classes we need with reflection
Expand Down Expand Up @@ -123,7 +128,11 @@ public void execute() throws MojoExecutionException {
throw new MojoExecutionException("Error occurred while instantiating a Groovy class from classpath.", e);
} finally {
if (!allowSystemExits) {
System.setSecurityManager(sm);
try {
System.setSecurityManager(new NoExitSecurityManager());
} catch (UnsupportedOperationException e) {
getLog().warn("Attempted to use Security Manager in a JVM where it's disabled by default. You might try `-Djava.security.manager=disallow` to override this.");
}
}
}
} else {
Expand Down

0 comments on commit 60ad8a7

Please sign in to comment.