1 /*
   2  * Copyright 2003-2009 Sun Microsystems, Inc.  All Rights Reserved.
   3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
   4  *
   5  * This code is free software; you can redistribute it and/or modify it
   6  * under the terms of the GNU General Public License version 2 only, as
   7  * published by the Free Software Foundation.  Sun designates this
   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");
 133 
 134     // java.net.ResponseCache
 135     public static final NetPermission SET_RESPONSECACHE_PERMISSION =
 136        new NetPermission("setResponseCache");
 137 
 138     // java.net.ResponseCache
 139     public static final NetPermission GET_RESPONSECACHE_PERMISSION =
 140        new NetPermission("getResponseCache");
 141 
 142     // java.lang.SecurityManager, sun.applet.AppletPanel, sun.misc.Launcher
 143     public static final RuntimePermission CREATE_CLASSLOADER_PERMISSION =
 144         new RuntimePermission("createClassLoader");
 145 
 146     // java.lang.SecurityManager
 147     public static final RuntimePermission CHECK_MEMBER_ACCESS_PERMISSION =
 148         new RuntimePermission("accessDeclaredMembers");
 149 
 150     // java.lang.SecurityManager, sun.applet.AppletSecurity
 151     public static final RuntimePermission MODIFY_THREAD_PERMISSION =
 152         new RuntimePermission("modifyThread");
 153 
 154     // java.lang.SecurityManager, sun.applet.AppletSecurity
 155     public static final RuntimePermission MODIFY_THREADGROUP_PERMISSION =
 156         new RuntimePermission("modifyThreadGroup");
 157 
 158     // java.lang.Class
 159     public static final RuntimePermission GET_PD_PERMISSION =
 160         new RuntimePermission("getProtectionDomain");
 161 
 162     // java.lang.Class, java.lang.ClassLoader, java.lang.Thread
 163     public static final RuntimePermission GET_CLASSLOADER_PERMISSION =
 164         new RuntimePermission("getClassLoader");
 165 
 166     // java.lang.Thread
 167     public static final RuntimePermission STOP_THREAD_PERMISSION =
 168        new RuntimePermission("stopThread");
 169 
 170     // java.lang.Thread
 171     public static final RuntimePermission GET_STACK_TRACE_PERMISSION =
 172        new RuntimePermission("getStackTrace");
 173 
 174     // java.security.AccessControlContext
 175     public static final SecurityPermission CREATE_ACC_PERMISSION =
 176        new SecurityPermission("createAccessControlContext");
 177 
 178     // java.security.AccessControlContext
 179     public static final SecurityPermission GET_COMBINER_PERMISSION =
 180        new SecurityPermission("getDomainCombiner");
 181 
 182     // java.security.Policy, java.security.ProtectionDomain
 183     public static final SecurityPermission GET_POLICY_PERMISSION =
 184         new SecurityPermission ("getPolicy");
 185 
 186     // java.lang.SecurityManager
 187     public static final SocketPermission LOCAL_LISTEN_PERMISSION =
 188         new SocketPermission("localhost:1024-", SOCKET_LISTEN_ACTION);
 189 
 190     // javax.security.auth.Subject
 191     public static final AuthPermission DO_AS_PERMISSION =
 192         new AuthPermission("doAs");
 193 
 194     // javax.security.auth.Subject
 195     public static final AuthPermission DO_AS_PRIVILEGED_PERMISSION =
 196         new AuthPermission("doAsPrivileged");
 197 }