public class DebugDynamicPolicyProvider extends DynamicPolicyProvider
DynamicPolicy
that logs information about missing
permissions, and optionally grants all permissions, which is FOR
DEBUGGING ONLY. Do not use this security policy provider to grant
all permissions in a production environment. This class is intended to simplify the process of deciding what security permissions to grant to run an application. While it is generally acceptable to grant all permissions to local, trusted code, downloaded code should typically be granted the least permission possible.
The usual approach to choosing which permissions to grant is to start by running the application with a security policy file that grants all permissions to local, trusted code. When the application fails with an exception message that identifies a missing permission, add that permission to the security policy file, and repeat the process. Although straight forward, this process can be time consuming if the application requires many permission grants.
Another approach is to set the value of the
"java.security.debug"
system property to
"access,failure"
, which produces debugging output that
describes permission grants and failures. Unfortunately, this approach
produces voluminous output, making it difficult to determine which
permission grants are needed.
This security policy provider permits another, hopefully more convenient, approach. When this class is specified as the security policy provider, and granting all permissions is enabled, it uses the standard dynamic security policy to determine what permissions are granted. If a permission is not granted by the standard policy, though, then rather than denying permission, this class logs the missing permission in the form required by the security policy file, and grants the permission, allowing the program to continue. In this way, developers can determine the complete set of security permissions required by the application.
Note that the information printed by this security policy provider may
not be in the form you wish to use in your policy file. In particular,
using system property substitutions and KeyStore
aliases
may produce a more portable file than one containing the exact entries
logged. Note, too, that the information printed for
signedBy
fields specifies the principal name for
X.509
certificates, rather than the KeyStore
alias, which is not a valid security policy file format.
Using this security policy provider without granting all permissions is also useful since it prints information about security exceptions that were caught, but that might have an affect on program behavior.
This class uses uses the Logger
named
net.jini.security.policy
to log information at the following
levels:
WARNING
- Permissions that were needed but not
granted by the policy file.
FINE
- Also include stack traces.
FINER
- All permissions granted, with stack traces
for ones not granted by the policy file, and dynamic grants.
FINEST
- All permissions granted, with all stack
traces, and dynamic grants. jsk-policy.jar
file from the lib-ext
subdirectory of the Apache River release
installation to the extensions directory of the Java(TM) 2 SDK (or JRE)
installation, and copy the jsk-debug-policy.jar
file
from the lib
subdirectory of the Apache River release installation to
the extensions directory of the Java 2 SDK (or JRE) installation.
jre/lib/security/security/java.security
, modify the
file to contain the line:
and then specify this new file as the value of thepolicy.provider=com.sun.jini.tool.DebugDynamicPolicyProvider
java.security.properties
system property.
com.sun.jini.tool.DebugDynamicPolicyProvider.grantAll
security
property to true
by adding the following line to the security
properties file:
com.sun.jini.tool.DebugDynamicPolicyProvider.grantAll=true
Granting all permissions is disabled by default.
Make sure to specify a security manager, either by setting the
java.security.manager
system property, or putting the following
code in the main method of the application:
if (System.getSecurityManager() == null) { System.setSecurityManager(new SecurityManager()); }
This provider can be used in conjunction with the provider
com.sun.jini.start.AggregatePolicyProvider
by setting the
com.sun.jini.start.AggregatePolicyProvider.mainPolicyClass
system property to the fully qualified name of this class. If this
provider is used with the AggregatePolicyProvider
, then the
JAR file jsk-debug-policy.jar
needs to be in the
application's class path, and this class needs to be granted all
permissions.
Modifier and Type | Class and Description |
---|---|
private static class |
DebugDynamicPolicyProvider.Request |
Policy.Parameters
Modifier and Type | Field and Description |
---|---|
private static CodeSource |
emptyCS
The empty codesource.
|
private static boolean |
grantAll |
private static Logger |
logger |
private static Set |
requests |
UNSUPPORTED_EMPTY_COLLECTION
Constructor and Description |
---|
DebugDynamicPolicyProvider()
Creates an instance of this class that wraps a default underlying
policy, as specified by
DynamicPolicyProvider() . |
DebugDynamicPolicyProvider(Policy basePolicy)
Creates an instance of this class that wraps around the given
non-
null base policy object. |
Modifier and Type | Method and Description |
---|---|
private static String |
getCertName(Certificate cert)
Returns the name of the certificate.
|
void |
grant(Class cl,
Principal[] principals,
Permission[] permissions)
Log calls.
|
boolean |
implies(ProtectionDomain pd,
Permission perm)
Always returns true, but logs unique requests
|
private static String |
quoteString(String s)
Returns a quoted version of the argument, such that it would result in
the argument if read from a file with the standard String syntax.
|
getGrants, getPermissions, getPermissions, grantSupported, refresh
getInstance, getInstance, getInstance, getParameters, getPolicy, getProvider, getType, setPolicy
private static final Logger logger
private static boolean grantAll
private static final Set requests
private static final CodeSource emptyCS
public DebugDynamicPolicyProvider() throws PolicyInitializationException
DynamicPolicyProvider()
.PolicyInitializationException
- if unable to construct the base
policySecurityException
- if there is a security manager and the calling
context does not have adequate permissions to read the
net.jini.security.policy.DynamicPolicyProvider.basePolicyClass
security property, or if the calling context does not
have adequate permissions to access the base policy classpublic DebugDynamicPolicyProvider(Policy basePolicy)
null
base policy object.basePolicy
- base policy object containing information about
non-dynamic grantsNullPointerException
- if basePolicy
is
null
public void grant(Class cl, Principal[] principals, Permission[] permissions)
grant
in interface DynamicPolicy
grant
in class DynamicPolicyProvider
cl
- class to grant permissions to the class loader of, or
null
if granting across all class loadersprincipals
- if non-null
, minimum set of principals
to which grants applypermissions
- if non-null
, permissions to grantpublic boolean implies(ProtectionDomain pd, Permission perm)
implies
in class DynamicPolicyProvider
private static String getCertName(Certificate cert)
Copyright 2007-2013, multiple authors.
Licensed under the Apache License, Version 2.0, see the NOTICE file for attributions.