Voici le code pour obtenir la liste des sources de données en utilisant JMX CONFIGURES:
public synchronized List<String> getDBPools() {
return (List) WSSubject.doAs(this.adminSubject,
new java.security.PrivilegedAction() {
public Object run() {
// Subject is associated with the current thread context
return java.security.AccessController
.doPrivileged(new java.security.PrivilegedAction() {
public Object run() {
List<String> result = new ArrayList<String>();
try {
Session session = new Session();
// Get the ConfigService
// implementation.
ConfigService configService = ConfigServiceFactory
.getConfigService();
ObjectName dsType = ConfigServiceHelper
.createObjectName(null,
"DataSource", null);
ObjectName[] datasources = configService
.queryConfigObjects(
session, null,
dsType, null);
for (int i = 0; i < datasources.length; i++) {
ObjectName dsObject = datasources[i];
log
.debug("OBJ NAME = "
+ dsObject
.getKeyProperty(SystemAttributes._WEBSPHERE_CONFIG_DATA_DISPLAY_NAME));
log
.debug("OBJ ID = "
+ dsObject
.getKeyProperty(SystemAttributes._WEBSPHERE_CONFIG_DATA_ID));
log
.debug("OBJ TYPE = "
+ dsObject
.getKeyProperty(SystemAttributes._WEBSPHERE_CONFIG_DATA_TYPE));
String dsName = dsObject
.getKeyProperty(SystemAttributes._WEBSPHERE_CONFIG_DATA_DISPLAY_NAME);
if (!dsName
.equals("DefaultEJBTimerDataSource")) {
result.add(dsName);
}
}
} catch (ConfigServiceException ex) {
log
.error(
"Error in JMX Query string",
ex);
} catch (ConnectorException ex) {
log
.error(
"Error connecting to the admin service",
ex);
}
return result;
}
});
}
});
}