forked from linkedin/dr-elephant
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Global.java
90 lines (76 loc) · 2.7 KB
/
Global.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
/*
* Copyright 2016 LinkedIn Corp.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy of
* the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*/
import com.linkedin.drelephant.DrElephant;
import com.sun.security.sasl.util.AbstractSaslImpl;
import play.Application;
import play.GlobalSettings;
import play.Logger;
import java.io.IOException;
import java.lang.reflect.Field;
import java.lang.reflect.Modifier;
import java.util.logging.Level;
/**
* This class manages all the global settings
*/
public class Global extends GlobalSettings {
DrElephant _drElephant;
public void onStart(Application app) {
Logger.info("Starting Application...");
fixJavaKerberos();
try {
_drElephant = new DrElephant();
_drElephant.start();
} catch (IOException e) {
Logger.error("Application start failed...", e);
}
}
public void onStop(Application app) {
Logger.info("Stopping application...");
if (_drElephant != null) {
_drElephant.kill();
}
}
/**
* This hack is done in order to fix a problem in Java 1.6 when using Kerberos
* <p/>
* Specific error:
* java.lang.NullPointerException
* at com.sun.security.sasl.util.AbstractSaslImpl.traceOutput(AbstractSaslImpl.java:241)
* at com.sun.security.sasl.gsskerb.GssKrb5Client.evaluateChallenge(GssKrb5Client.java:180)
*/
private static void fixJavaKerberos() {
try {
Field loggerField = AbstractSaslImpl.class.getDeclaredField("logger");
loggerField.setAccessible(true);
java.util.logging.Logger logger = (java.util.logging.Logger) loggerField.get(null);
if (logger == null) {
logger = java.util.logging.Logger.getLogger("javax.security.sasl");
setFinalStatic(loggerField, logger);
}
//Prevent the code in GssKrb5Client.evaluateChallenge to call traceOutput()
logger.setLevel(Level.OFF);
} catch (Exception e) {
Logger.error("Error trying to fix Kerberos connection", e);
}
}
static void setFinalStatic(Field field, Object newValue) throws Exception {
field.setAccessible(true);
Field modifiersField = Field.class.getDeclaredField("modifiers");
modifiersField.setAccessible(true);
modifiersField.setInt(field, field.getModifiers() & ~Modifier.FINAL);
field.set(null, newValue);
}
}