| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 | [[modules-scripting-security]]=== Scripting and the Java Security ManagerElasticsearch runs with the https://docs.oracle.com/javase/tutorial/essential/environment/security.html[Java Security Manager]enabled by default.  The security policy in Elasticsearch locks down thepermissions granted to each class to the bare minimum required to operate.The benefit of doing this is that it severely limits the attack vectorsavailable to a hacker.Restricting permissions is particularly important with scripting languageslike Groovy and Javascript which are designed to do anything that can be donein Java itself, including writing to the file system, opening sockets toremote servers, etc.[float]=== Script Classloader WhitelistScripting languages are only allowed to load classes which appear in ahardcoded whitelist that can be found inhttps://github.com/elastic/elasticsearch/blob/{branch}/core/src/main/java/org/elasticsearch/script/ClassPermission.java[`org.elasticsearch.script.ClassPermission`].In a script, attempting to load a class that does not appear in the whitelist_may_ result in a `ClassNotFoundException`, for instance this script:[source,json]------------------------------GET _search{  "script_fields": {    "the_hour": {      "script": "use(java.math.BigInteger); new BigInteger(1)"    }  }}------------------------------will return the following exception:[source,json]------------------------------{  "reason": {    "type": "script_exception",    "reason": "failed to run inline script [use(java.math.BigInteger); new BigInteger(1)] using lang [groovy]",    "caused_by": {      "type": "no_class_def_found_error",      "reason": "java/math/BigInteger",      "caused_by": {        "type": "class_not_found_exception",        "reason": "java.math.BigInteger"      }    }  }}------------------------------However, classloader issues may also result in more difficult to interpretexceptions.  For instance, this script:[source,groovy]------------------------------use(groovy.time.TimeCategory); new Date(123456789).format('HH')------------------------------Returns the following exception:[source,json]------------------------------{  "reason": {    "type": "script_exception",    "reason": "failed to run inline script [use(groovy.time.TimeCategory); new Date(123456789).format('HH')] using lang [groovy]",    "caused_by": {      "type": "missing_property_exception",      "reason": "No such property: groovy for class: 8d45f5c1a07a1ab5dda953234863e283a7586240"    }  }}------------------------------[float]== Dealing with Java Security Manager issuesIf you encounter issues with the Java Security Manager, you have two optionsfor resolving these issues:[float]=== Fix the security problemThe safest and most secure long term solution is to change the code causingthe security issue.  We recognise that this may take time to do correctly andso we provide the following two alternatives.[float]=== Customising the classloader whitelistThe classloader whitelist can be customised by tweaking the local JavaSecurity Policy either:* system wide: `$JAVA_HOME/lib/security/java.policy`,* for just the `elasticsearch` user: `/home/elasticsearch/.java.policy`, or* from a file specified in the `JAVA_OPTS` environment variable with `-Djava.security.policy=someURL`:+[source,js]---------------------------------export JAVA_OPTS="${JAVA_OPTS} -Djava.security.policy=file:///path/to/my.policy`./bin/elasticsearch---------------------------------Permissions may be granted at the class, package, or global level.  For instance:[source,js]----------------------------------grant {    permission org.elasticsearch.script.ClassPermission "java.util.Base64"; // allow class    permission org.elasticsearch.script.ClassPermission "java.util.*"; // allow package    permission org.elasticsearch.script.ClassPermission "*"; // allow all (disables filtering basically)};----------------------------------Here is an example of how to enable the `groovy.time.TimeCategory` class:[source,js]----------------------------------grant {    permission org.elasticsearch.script.ClassPermission "java.lang.Class";    permission org.elasticsearch.script.ClassPermission "groovy.time.TimeCategory";};----------------------------------[TIP]======================================Before adding classes to the whitelist, consider the security impact that itwill have on Elasticsearch. Do you really need an extra class or can your codebe rewritten in a more secure way?It is quite possible that we have not whitelisted a generically useful andsafe class. If you have a class that you think should be whitelisted bydefault, please open an issue on GitHub and we will consider the impact ofdoing so.======================================See http://docs.oracle.com/javase/7/docs/technotes/guides/security/PolicyFiles.html for more information.
 |