8 * particular file as subject to the "Classpath" exception as provided 9 * by Sun in the LICENSE file that accompanied this code. 10 * 11 * This code is distributed in the hope that it will be useful, but WITHOUT 12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 14 * version 2 for more details (a copy is included in the LICENSE file that 15 * accompanied this code). 16 * 17 * You should have received a copy of the GNU General Public License version 18 * 2 along with this work; if not, write to the Free Software Foundation, 19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 20 * 21 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, 22 * CA 95054 USA or visit www.sun.com if you need additional information or 23 * have any questions. 24 */ 25 26 package sun.security.util; 27 28 import java.io.FilePermission; 29 import java.awt.AWTPermission; 30 import java.util.PropertyPermission; 31 import java.lang.RuntimePermission; 32 import java.net.SocketPermission; 33 import java.net.NetPermission; 34 import java.security.SecurityPermission; 35 import java.security.AllPermission; 36 import javax.security.auth.AuthPermission; 37 38 /** 39 * Permission constants and string constants used to create permissions 40 * used throughout the JDK. 41 */ 42 public final class SecurityConstants { 43 // Cannot create one of these 44 private SecurityConstants () { 45 } 46 47 // Commonly used string constants for permission actions used by 48 // SecurityManager. Declare here for shortcut when checking permissions 49 // in FilePermission, SocketPermission, and PropertyPermission. 50 51 public static final String FILE_DELETE_ACTION = "delete"; 52 public static final String FILE_EXECUTE_ACTION = "execute"; 53 public static final String FILE_READ_ACTION = "read"; 54 public static final String FILE_WRITE_ACTION = "write"; 55 public static final String FILE_READLINK_ACTION = "readlink"; 56 57 public static final String SOCKET_RESOLVE_ACTION = "resolve"; 58 public static final String SOCKET_CONNECT_ACTION = "connect"; 59 public static final String SOCKET_LISTEN_ACTION = "listen"; 60 public static final String SOCKET_ACCEPT_ACTION = "accept"; 61 public static final String SOCKET_CONNECT_ACCEPT_ACTION = "connect,accept"; 62 63 public static final String PROPERTY_RW_ACTION = "read,write"; 64 public static final String PROPERTY_READ_ACTION = "read"; 65 public static final String PROPERTY_WRITE_ACTION = "write"; 66 67 // Permission constants used in the various checkPermission() calls in JDK. 68 69 // java.lang.Class, java.lang.SecurityManager, java.lang.System, 70 // java.net.URLConnection, java.security.AllPermission, java.security.Policy, 71 // sun.security.provider.PolicyFile 72 public static final AllPermission ALL_PERMISSION = new AllPermission(); 73 74 // java.lang.SecurityManager 75 public static final AWTPermission TOPLEVEL_WINDOW_PERMISSION = 76 new AWTPermission("showWindowWithoutWarningBanner"); 77 78 // java.lang.SecurityManager 79 public static final AWTPermission ACCESS_CLIPBOARD_PERMISSION = 80 new AWTPermission("accessClipboard"); 81 82 // java.lang.SecurityManager 83 public static final AWTPermission CHECK_AWT_EVENTQUEUE_PERMISSION = 84 new AWTPermission("accessEventQueue"); 85 86 // java.awt.Dialog 87 public static final AWTPermission TOOLKIT_MODALITY_PERMISSION = 88 new AWTPermission("toolkitModality"); 89 90 // java.awt.Robot 91 public static final AWTPermission READ_DISPLAY_PIXELS_PERMISSION = 92 new AWTPermission("readDisplayPixels"); 93 94 // java.awt.Robot 95 public static final AWTPermission CREATE_ROBOT_PERMISSION = 96 new AWTPermission("createRobot"); 97 98 // java.awt.MouseInfo 99 public static final AWTPermission WATCH_MOUSE_PERMISSION = 100 new AWTPermission("watchMousePointer"); 101 102 // java.awt.Window 103 public static final AWTPermission SET_WINDOW_ALWAYS_ON_TOP_PERMISSION = 104 new AWTPermission("setWindowAlwaysOnTop"); 105 106 // java.awt.Toolkit 107 public static final AWTPermission ALL_AWT_EVENTS_PERMISSION = 108 new AWTPermission("listenToAllAWTEvents"); 109 110 // java.awt.SystemTray 111 public static final AWTPermission ACCESS_SYSTEM_TRAY_PERMISSION = 112 new AWTPermission("accessSystemTray"); 113 114 // java.net.URL 115 public static final NetPermission SPECIFY_HANDLER_PERMISSION = 116 new NetPermission("specifyStreamHandler"); 117 118 // java.net.ProxySelector 119 public static final NetPermission SET_PROXYSELECTOR_PERMISSION = 120 new NetPermission("setProxySelector"); 121 122 // java.net.ProxySelector 123 public static final NetPermission GET_PROXYSELECTOR_PERMISSION = 124 new NetPermission("getProxySelector"); 125 126 // java.net.CookieHandler 127 public static final NetPermission SET_COOKIEHANDLER_PERMISSION = 128 new NetPermission("setCookieHandler"); 129 130 // java.net.CookieHandler 131 public static final NetPermission GET_COOKIEHANDLER_PERMISSION = 132 new NetPermission("getCookieHandler"); | 8 * particular file as subject to the "Classpath" exception as provided 9 * by Sun in the LICENSE file that accompanied this code. 10 * 11 * This code is distributed in the hope that it will be useful, but WITHOUT 12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 14 * version 2 for more details (a copy is included in the LICENSE file that 15 * accompanied this code). 16 * 17 * You should have received a copy of the GNU General Public License version 18 * 2 along with this work; if not, write to the Free Software Foundation, 19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 20 * 21 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, 22 * CA 95054 USA or visit www.sun.com if you need additional information or 23 * have any questions. 24 */ 25 26 package sun.security.util; 27 28 import java.net.SocketPermission; 29 import java.net.NetPermission; 30 import java.security.AccessController; 31 import java.security.PrivilegedAction; 32 import java.security.Permission; 33 import java.security.BasicPermission; 34 import java.security.SecurityPermission; 35 import java.security.AllPermission; 36 import javax.security.auth.AuthPermission; 37 38 /** 39 * Permission constants and string constants used to create permissions 40 * used throughout the JDK. 41 */ 42 public final class SecurityConstants { 43 // Cannot create one of these 44 private SecurityConstants () { 45 } 46 47 // Commonly used string constants for permission actions used by 48 // SecurityManager. Declare here for shortcut when checking permissions 49 // in FilePermission, SocketPermission, and PropertyPermission. 50 51 public static final String FILE_DELETE_ACTION = "delete"; 52 public static final String FILE_EXECUTE_ACTION = "execute"; 53 public static final String FILE_READ_ACTION = "read"; 54 public static final String FILE_WRITE_ACTION = "write"; 55 public static final String FILE_READLINK_ACTION = "readlink"; 56 57 public static final String SOCKET_RESOLVE_ACTION = "resolve"; 58 public static final String SOCKET_CONNECT_ACTION = "connect"; 59 public static final String SOCKET_LISTEN_ACTION = "listen"; 60 public static final String SOCKET_ACCEPT_ACTION = "accept"; 61 public static final String SOCKET_CONNECT_ACCEPT_ACTION = "connect,accept"; 62 63 public static final String PROPERTY_RW_ACTION = "read,write"; 64 public static final String PROPERTY_READ_ACTION = "read"; 65 public static final String PROPERTY_WRITE_ACTION = "write"; 66 67 // Permission constants used in the various checkPermission() calls in JDK. 68 69 // java.lang.Class, java.lang.SecurityManager, java.lang.System, 70 // java.net.URLConnection, java.security.AllPermission, java.security.Policy, 71 // sun.security.provider.PolicyFile 72 public static final AllPermission ALL_PERMISSION = new AllPermission(); 73 74 /** 75 * Permission type used when AWT is not present. 76 */ 77 private static class FakeAWTPermission extends BasicPermission { 78 private static final long serialVersionUID = -1L; 79 public FakeAWTPermission(String name) { 80 super(name); 81 } 82 public String toString() { 83 return "(\"java.awt.AWTPermission\" \"" + getName() + "\")"; 84 } 85 } 86 87 /** 88 * Permission factory used when AWT is not present. 89 */ 90 private static class FakeAWTPermissionFactory 91 implements PermissionFactory<FakeAWTPermission> 92 { 93 @Override 94 public FakeAWTPermission newPermission(String name) { 95 return new FakeAWTPermission(name); 96 } 97 } 98 99 /** 100 * AWT Permissions used in the JDK. 101 */ 102 public static class AWT { 103 private AWT() { } 104 105 /** 106 * The class name of the factory to create java.awt.AWTPermission objects. 107 */ 108 private static final String AWTFactory = "sun.awt.AWTPermissionFactory"; 109 110 /** 111 * The PermissionFactory to create AWT permissions (or fake permissions 112 * if AWT is not present). 113 */ 114 private static final PermissionFactory<?> factory = permissionFactory(); 115 116 private static PermissionFactory<?> permissionFactory() { 117 Class<?> c = AccessController 118 .doPrivileged(new PrivilegedAction<Class<?>>() { 119 public Class<?> run() { 120 try { 121 return Class.forName(AWTFactory, true, null); 122 } catch (ClassNotFoundException e) { 123 // not available 124 return null; 125 } 126 }}); 127 if (c != null) { 128 // AWT present 129 try { 130 return (PermissionFactory<?>)c.newInstance(); 131 } catch (InstantiationException x) { 132 throw new InternalError(x.getMessage()); 133 } catch (IllegalAccessException x) { 134 throw new InternalError(x.getMessage()); 135 } 136 } else { 137 // AWT not present 138 return new FakeAWTPermissionFactory(); 139 } 140 } 141 142 private static Permission newAWTPermission(String name) { 143 return factory.newPermission(name); 144 } 145 146 // java.lang.SecurityManager 147 public static final Permission TOPLEVEL_WINDOW_PERMISSION = 148 newAWTPermission("showWindowWithoutWarningBanner"); 149 // java.lang.SecurityManager 150 public static final Permission ACCESS_CLIPBOARD_PERMISSION = 151 newAWTPermission("accessClipboard"); 152 153 // java.lang.SecurityManager 154 public static final Permission CHECK_AWT_EVENTQUEUE_PERMISSION = 155 newAWTPermission("accessEventQueue"); 156 157 // java.awt.Dialog 158 public static final Permission TOOLKIT_MODALITY_PERMISSION = 159 newAWTPermission("toolkitModality"); 160 161 // java.awt.Robot 162 public static final Permission READ_DISPLAY_PIXELS_PERMISSION = 163 newAWTPermission("readDisplayPixels"); 164 165 // java.awt.Robot 166 public static final Permission CREATE_ROBOT_PERMISSION = 167 newAWTPermission("createRobot"); 168 169 // java.awt.MouseInfo 170 public static final Permission WATCH_MOUSE_PERMISSION = 171 newAWTPermission("watchMousePointer"); 172 173 // java.awt.Window 174 public static final Permission SET_WINDOW_ALWAYS_ON_TOP_PERMISSION = 175 newAWTPermission("setWindowAlwaysOnTop"); 176 177 // java.awt.Toolkit 178 public static final Permission ALL_AWT_EVENTS_PERMISSION = 179 newAWTPermission("listenToAllAWTEvents"); 180 181 // java.awt.SystemTray 182 public static final Permission ACCESS_SYSTEM_TRAY_PERMISSION = 183 newAWTPermission("accessSystemTray"); 184 } 185 186 // java.net.URL 187 public static final NetPermission SPECIFY_HANDLER_PERMISSION = 188 new NetPermission("specifyStreamHandler"); 189 190 // java.net.ProxySelector 191 public static final NetPermission SET_PROXYSELECTOR_PERMISSION = 192 new NetPermission("setProxySelector"); 193 194 // java.net.ProxySelector 195 public static final NetPermission GET_PROXYSELECTOR_PERMISSION = 196 new NetPermission("getProxySelector"); 197 198 // java.net.CookieHandler 199 public static final NetPermission SET_COOKIEHANDLER_PERMISSION = 200 new NetPermission("setCookieHandler"); 201 202 // java.net.CookieHandler 203 public static final NetPermission GET_COOKIEHANDLER_PERMISSION = 204 new NetPermission("getCookieHandler"); |