0N/A/*
2362N/A * Copyright (c) 2003, 2009, Oracle and/or its affiliates. All rights reserved.
0N/A * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
0N/A *
0N/A * This code is free software; you can redistribute it and/or modify it
0N/A * under the terms of the GNU General Public License version 2 only, as
2362N/A * published by the Free Software Foundation. Oracle designates this
0N/A * particular file as subject to the "Classpath" exception as provided
2362N/A * by Oracle in the LICENSE file that accompanied this code.
0N/A *
0N/A * This code is distributed in the hope that it will be useful, but WITHOUT
0N/A * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
0N/A * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
0N/A * version 2 for more details (a copy is included in the LICENSE file that
0N/A * accompanied this code).
0N/A *
0N/A * You should have received a copy of the GNU General Public License version
0N/A * 2 along with this work; if not, write to the Free Software Foundation,
0N/A * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
0N/A *
2362N/A * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
2362N/A * or visit www.oracle.com if you need additional information or have any
2362N/A * questions.
0N/A */
0N/A
0N/Apackage sun.security.util;
0N/A
0N/Aimport java.net.SocketPermission;
0N/Aimport java.net.NetPermission;
1714N/Aimport java.security.AccessController;
1714N/Aimport java.security.PrivilegedAction;
1714N/Aimport java.security.Permission;
1714N/Aimport java.security.BasicPermission;
0N/Aimport java.security.SecurityPermission;
0N/Aimport java.security.AllPermission;
0N/A
0N/A/**
0N/A * Permission constants and string constants used to create permissions
0N/A * used throughout the JDK.
0N/A */
0N/Apublic final class SecurityConstants {
0N/A // Cannot create one of these
0N/A private SecurityConstants () {
0N/A }
0N/A
0N/A // Commonly used string constants for permission actions used by
0N/A // SecurityManager. Declare here for shortcut when checking permissions
0N/A // in FilePermission, SocketPermission, and PropertyPermission.
0N/A
0N/A public static final String FILE_DELETE_ACTION = "delete";
0N/A public static final String FILE_EXECUTE_ACTION = "execute";
0N/A public static final String FILE_READ_ACTION = "read";
0N/A public static final String FILE_WRITE_ACTION = "write";
893N/A public static final String FILE_READLINK_ACTION = "readlink";
0N/A
0N/A public static final String SOCKET_RESOLVE_ACTION = "resolve";
0N/A public static final String SOCKET_CONNECT_ACTION = "connect";
0N/A public static final String SOCKET_LISTEN_ACTION = "listen";
0N/A public static final String SOCKET_ACCEPT_ACTION = "accept";
0N/A public static final String SOCKET_CONNECT_ACCEPT_ACTION = "connect,accept";
0N/A
0N/A public static final String PROPERTY_RW_ACTION = "read,write";
0N/A public static final String PROPERTY_READ_ACTION = "read";
0N/A public static final String PROPERTY_WRITE_ACTION = "write";
0N/A
0N/A // Permission constants used in the various checkPermission() calls in JDK.
0N/A
0N/A // java.lang.Class, java.lang.SecurityManager, java.lang.System,
0N/A // java.net.URLConnection, java.security.AllPermission, java.security.Policy,
0N/A // sun.security.provider.PolicyFile
0N/A public static final AllPermission ALL_PERMISSION = new AllPermission();
0N/A
1714N/A /**
1714N/A * Permission type used when AWT is not present.
1714N/A */
1714N/A private static class FakeAWTPermission extends BasicPermission {
1714N/A private static final long serialVersionUID = -1L;
1714N/A public FakeAWTPermission(String name) {
1714N/A super(name);
1714N/A }
1714N/A public String toString() {
1714N/A return "(\"java.awt.AWTPermission\" \"" + getName() + "\")";
1714N/A }
1714N/A }
0N/A
1714N/A /**
1714N/A * Permission factory used when AWT is not present.
1714N/A */
1714N/A private static class FakeAWTPermissionFactory
1714N/A implements PermissionFactory<FakeAWTPermission>
1714N/A {
1714N/A @Override
1714N/A public FakeAWTPermission newPermission(String name) {
1714N/A return new FakeAWTPermission(name);
1714N/A }
1714N/A }
0N/A
1714N/A /**
1714N/A * AWT Permissions used in the JDK.
1714N/A */
1714N/A public static class AWT {
1714N/A private AWT() { }
0N/A
1714N/A /**
1714N/A * The class name of the factory to create java.awt.AWTPermission objects.
1714N/A */
1714N/A private static final String AWTFactory = "sun.awt.AWTPermissionFactory";
1714N/A
1714N/A /**
1714N/A * The PermissionFactory to create AWT permissions (or fake permissions
1714N/A * if AWT is not present).
1714N/A */
1714N/A private static final PermissionFactory<?> factory = permissionFactory();
0N/A
1714N/A private static PermissionFactory<?> permissionFactory() {
1714N/A Class<?> c = AccessController
1714N/A .doPrivileged(new PrivilegedAction<Class<?>>() {
1714N/A public Class<?> run() {
1714N/A try {
1714N/A return Class.forName(AWTFactory, true, null);
1714N/A } catch (ClassNotFoundException e) {
1714N/A // not available
1714N/A return null;
1714N/A }
1714N/A }});
1714N/A if (c != null) {
1714N/A // AWT present
1714N/A try {
1714N/A return (PermissionFactory<?>)c.newInstance();
1714N/A } catch (InstantiationException x) {
1714N/A throw new InternalError(x.getMessage());
1714N/A } catch (IllegalAccessException x) {
1714N/A throw new InternalError(x.getMessage());
1714N/A }
1714N/A } else {
1714N/A // AWT not present
1714N/A return new FakeAWTPermissionFactory();
1714N/A }
1714N/A }
0N/A
1714N/A private static Permission newAWTPermission(String name) {
1714N/A return factory.newPermission(name);
1714N/A }
1714N/A
1714N/A // java.lang.SecurityManager
1714N/A public static final Permission TOPLEVEL_WINDOW_PERMISSION =
1714N/A newAWTPermission("showWindowWithoutWarningBanner");
0N/A
1714N/A // java.lang.SecurityManager
1714N/A public static final Permission ACCESS_CLIPBOARD_PERMISSION =
1714N/A newAWTPermission("accessClipboard");
1714N/A
1714N/A // java.lang.SecurityManager
1714N/A public static final Permission CHECK_AWT_EVENTQUEUE_PERMISSION =
1714N/A newAWTPermission("accessEventQueue");
1714N/A
1714N/A // java.awt.Dialog
1714N/A public static final Permission TOOLKIT_MODALITY_PERMISSION =
1714N/A newAWTPermission("toolkitModality");
1714N/A
1714N/A // java.awt.Robot
1714N/A public static final Permission READ_DISPLAY_PIXELS_PERMISSION =
1714N/A newAWTPermission("readDisplayPixels");
0N/A
1714N/A // java.awt.Robot
1714N/A public static final Permission CREATE_ROBOT_PERMISSION =
1714N/A newAWTPermission("createRobot");
1714N/A
1714N/A // java.awt.MouseInfo
1714N/A public static final Permission WATCH_MOUSE_PERMISSION =
1714N/A newAWTPermission("watchMousePointer");
0N/A
1714N/A // java.awt.Window
1714N/A public static final Permission SET_WINDOW_ALWAYS_ON_TOP_PERMISSION =
1714N/A newAWTPermission("setWindowAlwaysOnTop");
1714N/A
1714N/A // java.awt.Toolkit
1714N/A public static final Permission ALL_AWT_EVENTS_PERMISSION =
1714N/A newAWTPermission("listenToAllAWTEvents");
1714N/A
1714N/A // java.awt.SystemTray
1714N/A public static final Permission ACCESS_SYSTEM_TRAY_PERMISSION =
1714N/A newAWTPermission("accessSystemTray");
1714N/A }
0N/A
0N/A // java.net.URL
0N/A public static final NetPermission SPECIFY_HANDLER_PERMISSION =
0N/A new NetPermission("specifyStreamHandler");
0N/A
0N/A // java.net.ProxySelector
0N/A public static final NetPermission SET_PROXYSELECTOR_PERMISSION =
0N/A new NetPermission("setProxySelector");
0N/A
0N/A // java.net.ProxySelector
0N/A public static final NetPermission GET_PROXYSELECTOR_PERMISSION =
0N/A new NetPermission("getProxySelector");
0N/A
0N/A // java.net.CookieHandler
0N/A public static final NetPermission SET_COOKIEHANDLER_PERMISSION =
0N/A new NetPermission("setCookieHandler");
0N/A
0N/A // java.net.CookieHandler
0N/A public static final NetPermission GET_COOKIEHANDLER_PERMISSION =
0N/A new NetPermission("getCookieHandler");
0N/A
0N/A // java.net.ResponseCache
0N/A public static final NetPermission SET_RESPONSECACHE_PERMISSION =
0N/A new NetPermission("setResponseCache");
0N/A
0N/A // java.net.ResponseCache
0N/A public static final NetPermission GET_RESPONSECACHE_PERMISSION =
0N/A new NetPermission("getResponseCache");
0N/A
0N/A // java.lang.SecurityManager, sun.applet.AppletPanel, sun.misc.Launcher
0N/A public static final RuntimePermission CREATE_CLASSLOADER_PERMISSION =
0N/A new RuntimePermission("createClassLoader");
0N/A
0N/A // java.lang.SecurityManager
0N/A public static final RuntimePermission CHECK_MEMBER_ACCESS_PERMISSION =
0N/A new RuntimePermission("accessDeclaredMembers");
0N/A
0N/A // java.lang.SecurityManager, sun.applet.AppletSecurity
0N/A public static final RuntimePermission MODIFY_THREAD_PERMISSION =
0N/A new RuntimePermission("modifyThread");
0N/A
0N/A // java.lang.SecurityManager, sun.applet.AppletSecurity
0N/A public static final RuntimePermission MODIFY_THREADGROUP_PERMISSION =
0N/A new RuntimePermission("modifyThreadGroup");
0N/A
0N/A // java.lang.Class
0N/A public static final RuntimePermission GET_PD_PERMISSION =
0N/A new RuntimePermission("getProtectionDomain");
0N/A
0N/A // java.lang.Class, java.lang.ClassLoader, java.lang.Thread
0N/A public static final RuntimePermission GET_CLASSLOADER_PERMISSION =
0N/A new RuntimePermission("getClassLoader");
0N/A
0N/A // java.lang.Thread
0N/A public static final RuntimePermission STOP_THREAD_PERMISSION =
0N/A new RuntimePermission("stopThread");
0N/A
0N/A // java.lang.Thread
0N/A public static final RuntimePermission GET_STACK_TRACE_PERMISSION =
0N/A new RuntimePermission("getStackTrace");
0N/A
0N/A // java.security.AccessControlContext
0N/A public static final SecurityPermission CREATE_ACC_PERMISSION =
0N/A new SecurityPermission("createAccessControlContext");
0N/A
0N/A // java.security.AccessControlContext
0N/A public static final SecurityPermission GET_COMBINER_PERMISSION =
0N/A new SecurityPermission("getDomainCombiner");
0N/A
0N/A // java.security.Policy, java.security.ProtectionDomain
0N/A public static final SecurityPermission GET_POLICY_PERMISSION =
0N/A new SecurityPermission ("getPolicy");
0N/A
0N/A // java.lang.SecurityManager
0N/A public static final SocketPermission LOCAL_LISTEN_PERMISSION =
0N/A new SocketPermission("localhost:1024-", SOCKET_LISTEN_ACTION);
0N/A}