From a0100419b0070141d8816aada1a86384cc569981 Mon Sep 17 00:00:00 2001 From: Jason Zaugg Date: Tue, 28 Aug 2018 05:00:57 +0300 Subject: [PATCH] Reduce overhead of the security manager Continues the work started in #11 by systematically overriding all the other methods of SecurityManager for a fast path when the base security manager is null. Fixes #134 --- .../nailgun/NGSecurityManager.java | 138 +++++++++++++++++- 1 file changed, 137 insertions(+), 1 deletion(-) diff --git a/nailgun-server/src/main/java/com/martiansoftware/nailgun/NGSecurityManager.java b/nailgun-server/src/main/java/com/martiansoftware/nailgun/NGSecurityManager.java index 005e8ca9..7a9390e9 100644 --- a/nailgun-server/src/main/java/com/martiansoftware/nailgun/NGSecurityManager.java +++ b/nailgun-server/src/main/java/com/martiansoftware/nailgun/NGSecurityManager.java @@ -18,6 +18,8 @@ package com.martiansoftware.nailgun; +import java.io.FileDescriptor; +import java.net.InetAddress; import java.security.Permission; /** @@ -58,10 +60,144 @@ public void checkPermission(Permission perm, Object context) { } } - /** Avoid constructing a FilePermission object in checkRead if base manager is null. */ + // Overrides below avoid the cost of creating Permissions objects if base manager is null. + // FilePermission, in particular, is expensive to create. + public void checkRead(String file) { if (base != null) { super.checkRead(file); } } + + public void checkCreateClassLoader() { + if (base != null) { + super.checkCreateClassLoader(); + } + } + + public void checkAccess(Thread t) { + if (base != null) { + super.checkAccess(t); + } + } + + public void checkAccess(ThreadGroup g) { + if (base != null) { + super.checkAccess(g); + } + } + + public void checkExec(String cmd) { + if (base != null) { + super.checkExec(cmd); + } + } + + public void checkLink(String lib) { + if (base != null) { + super.checkLink(lib); + } + } + + public void checkRead(FileDescriptor fd) { + if (base != null) { + super.checkRead(fd); + } + } + + public void checkRead(String file, Object context) { + if (base != null) { + super.checkRead(file, context); + } + } + + public void checkWrite(FileDescriptor fd) { + if (base != null) { + super.checkWrite(fd); + } + } + + public void checkWrite(String file) { + if (base != null) { + super.checkWrite(file); + } + } + + public void checkDelete(String file) { + if (base != null) { + super.checkDelete(file); + } + } + + public void checkConnect(String host, int port) { + if (base != null) { + super.checkConnect(host, port); + } + } + + public void checkConnect(String host, int port, Object context) { + if (base != null) { + super.checkConnect(host, port, context); + } + } + + public void checkListen(int port) { + if (base != null) { + super.checkListen(port); + } + } + + public void checkAccept(String host, int port) { + if (base != null) { + super.checkAccept(host, port); + } + } + + public void checkMulticast(InetAddress maddr) { + if (base != null) { + super.checkMulticast(maddr); + } + } + + public void checkPropertiesAccess() { + if (base != null) { + super.checkPropertiesAccess(); + } + } + + public void checkPropertyAccess(String key) { + if (base != null) { + super.checkPropertyAccess(key); + } + } + + public void checkPrintJobAccess() { + if (base != null) { + super.checkPrintJobAccess(); + } + } + + public void checkPackageAccess(String pkg) { + if (base != null) { + super.checkPackageAccess(pkg); + } + } + + public void checkPackageDefinition(String pkg) { + if (base != null) { + super.checkPackageDefinition(pkg); + } + } + + public void checkSetFactory() { + if (base != null) { + super.checkSetFactory(); + } + } + + public void checkSecurityAccess(String target) { + if (base != null) { + super.checkSecurityAccess(target); + } + } }