use of org.glassfish.internal.data.ApplicationRegistry in project Payara by payara.
the class ListRestEndpointsCommand method getEndpointMap.
/**
* Returns a list of a map of endpoint -> list of methods.
* @param appName the name of the application.
* @throws IllegalArgumentException if the application does not contain endpoints. Specifies the reason.
*/
public Map<String, Set<String>> getEndpointMap(String appName) {
// Create an initial array
Map<String, Set<String>> endpoints = new TreeMap<>();
// Get all deployed applications
ApplicationRegistry appRegistry = habitat.getService(ApplicationRegistry.class);
// Get the deployed application with the provided name
ApplicationInfo appInfo = getSpecifiedApplication(appName, appRegistry);
// Check if the given application exists
if (appInfo == null) {
throw new IllegalArgumentException("Application " + appName + " is not registered.");
}
// Get the web modules from the given application (e.g. multiple wars in an ear)
List<WebModule> modules = getWebModules(appInfo);
// Check if the given application exists
if (modules.isEmpty()) {
throw new IllegalArgumentException("Application " + appName + " contains no web modules.");
}
// Get the Jersey applications from all of the modules (or only the one matching the given component name)
Map<ServletContainer, String> jerseyApplicationMap = getSpecifiedJerseyApplications(componentName, modules);
// error out in the case of a non existent provided component or no components at all
if (jerseyApplicationMap.isEmpty()) {
if (componentName == null) {
throw new IllegalArgumentException("Application " + appName + " has no deployed JAX-RS applications.");
}
throw new IllegalArgumentException("Component " + componentName + " could not be found.");
}
// loop through jersey components
boolean hasEndpoints = false;
for (ServletContainer jerseyApplication : jerseyApplicationMap.keySet()) {
String appRoot = jerseyApplication.getServletContext().getContextPath();
String jerseyAppRoot = jerseyApplicationMap.get(jerseyApplication);
List<Class<?>> containedClasses = getClasses(jerseyApplication);
// loop through all classes contained by given jersey application
for (Class<?> containedClass : containedClasses) {
List<RestEndpointModel> classEndpoints = getEndpointsForClass(containedClass);
if (!classEndpoints.isEmpty()) {
// loop through endpoints in given class
for (RestEndpointModel endpoint : classEndpoints) {
String path = appRoot + jerseyAppRoot + endpoint.getPath();
String method = endpoint.getRequestMethod();
if (endpoints.keySet().contains(path)) {
Set<String> methods = endpoints.get(path);
methods.add(method);
endpoints.put(path, methods);
} else {
endpoints.put(path, new TreeSet<>(asList(method)));
}
}
}
}
// Jersey will automatically generate a wadl file for the endpoints, so add
// it for every deployed application with endpoints
endpoints.put(appRoot + jerseyAppRoot + jerseyWADL, new TreeSet<>(asList(HttpMethod.GET)));
hasEndpoints = true;
}
if (!hasEndpoints) {
return null;
}
return endpoints;
}
use of org.glassfish.internal.data.ApplicationRegistry in project Payara by payara.
the class EjbRuntimeEndpointInfo method prepareInvocation.
public Object prepareInvocation(boolean doPreInvoke) throws Exception {
ComponentInvocation inv = null;
AdapterInvocationInfo adapterInvInfo = new AdapterInvocationInfo();
// init'ing jaxws is done here - this sequence is important
if (adapter == null) {
synchronized (this) {
if (adapter == null) {
try {
// Set webservice context here
// If the endpoint has a WebServiceContext with @Resource then
// that has to be used
EjbDescriptor ejbDesc = endpoint.getEjbComponentImpl();
Iterator<ResourceReferenceDescriptor> it = ejbDesc.getResourceReferenceDescriptors().iterator();
while (it.hasNext()) {
ResourceReferenceDescriptor r = it.next();
if (r.isWebServiceContext()) {
Iterator<InjectionTarget> iter = r.getInjectionTargets().iterator();
boolean matchingClassFound = false;
while (iter.hasNext()) {
InjectionTarget target = iter.next();
if (ejbDesc.getEjbClassName().equals(target.getClassName())) {
matchingClassFound = true;
break;
}
}
if (!matchingClassFound) {
continue;
}
try {
javax.naming.InitialContext ic = new javax.naming.InitialContext();
wsCtxt = (WebServiceContextImpl) ic.lookup("java:comp/env/" + r.getName());
} catch (Throwable t) {
if (logger.isLoggable(Level.FINE)) {
logger.log(Level.FINE, LogUtils.ERROR_EREI, t.getCause());
}
}
}
}
if (wsCtxt == null) {
wsCtxt = new WebServiceContextImpl();
}
} catch (Throwable t) {
LogHelper.log(logger, Level.SEVERE, LogUtils.CANNOT_INITIALIZE, t, endpoint.getName());
return null;
}
}
}
}
if (doPreInvoke) {
inv = container.startInvocation();
adapterInvInfo.setInv(inv);
}
// Now process handlers and init jaxws RI
synchronized (this) {
if (!handlersConfigured && doPreInvoke) {
try {
WsUtil wsu = new WsUtil();
String implClassName = endpoint.getEjbComponentImpl().getEjbClassName();
Class clazz = container.getEndpointClassLoader().loadClass(implClassName);
// Get the proper binding using BindingID
String givenBinding = endpoint.getProtocolBinding();
// Get list of all wsdls and schema
SDDocumentSource primaryWsdl = null;
Collection docs = null;
if (endpoint.getWebService().hasWsdlFile()) {
WebServiceContractImpl wscImpl = WebServiceContractImpl.getInstance();
ApplicationRegistry appRegistry = wscImpl.getApplicationRegistry();
ApplicationInfo appInfo = appRegistry.get(endpoint.getBundleDescriptor().getApplication().getRegistrationName());
URI deployedDir = appInfo.getSource().getURI();
URL pkgedWsdl;
if (deployedDir != null) {
if (endpoint.getBundleDescriptor().getApplication().isVirtual()) {
pkgedWsdl = deployedDir.resolve(endpoint.getWebService().getWsdlFileUri()).toURL();
} else {
String moduleUri1 = endpoint.getBundleDescriptor().getModuleDescriptor().getArchiveUri();
// Fix for issue 7024099
// Only replace the last "." with "_" for moduleDescriptor's archive uri
String moduleUri = FileUtils.makeFriendlyFilenameExtension(moduleUri1);
pkgedWsdl = deployedDir.resolve(moduleUri + "/" + endpoint.getWebService().getWsdlFileUri()).toURL();
}
} else {
pkgedWsdl = endpoint.getWebService().getWsdlFileUrl();
}
if (pkgedWsdl != null) {
primaryWsdl = SDDocumentSource.create(pkgedWsdl);
docs = wsu.getWsdlsAndSchemas(pkgedWsdl);
}
}
// Create a Container to pass ServletContext and also inserting the pipe
JAXWSContainer container = new JAXWSContainer(null, endpoint);
// Get catalog info
java.net.URL catalogURL = clazz.getResource('/' + endpoint.getBundleDescriptor().getDeploymentDescriptorDir() + File.separator + "jax-ws-catalog.xml");
// Create Binding and set service side handlers on this binding
boolean mtomEnabled = wsu.getMtom(endpoint);
WSBinding binding = null;
ArrayList<WebServiceFeature> wsFeatures = new ArrayList<WebServiceFeature>();
// Only if MTOm is enabled create the Binding with the MTOMFeature
if (mtomEnabled) {
int mtomThreshold = endpoint.getMtomThreshold() != null ? Integer.parseInt(endpoint.getMtomThreshold()) : 0;
MTOMFeature mtom = new MTOMFeature(true, mtomThreshold);
wsFeatures.add(mtom);
}
Addressing addressing = endpoint.getAddressing();
if (endpoint.getAddressing() != null) {
AddressingFeature addressingFeature = new AddressingFeature(addressing.isEnabled(), addressing.isRequired(), getResponse(addressing.getResponses()));
wsFeatures.add(addressingFeature);
}
if (wsFeatures.size() > 0) {
binding = BindingID.parse(givenBinding).createBinding(wsFeatures.toArray(new WebServiceFeature[wsFeatures.size()]));
} else {
binding = BindingID.parse(givenBinding).createBinding();
}
wsu.configureJAXWSServiceHandlers(endpoint, endpoint.getProtocolBinding(), binding);
// See if it is configured with JAX-WS extension InstanceResolver annotation like
// @com.sun.xml.ws.developer.servlet.HttpSessionScope or @com.sun.xml.ws.developer.Stateful
// #GLASSFISH-21081
InstanceResolver ir = InstanceResolver.createFromInstanceResolverAnnotation(clazz);
// TODO - Implement 109 StatefulInstanceResolver ??
if (ir == null) {
// use our own InstanceResolver that does not call @PostConstuct method before
// @Resource injections have happened.
ir = new InstanceResolverImpl(clazz);
}
// Create the jaxws2.1 invoker and use this
Invoker invoker = ir.createInvoker();
WSEndpoint wsep = WSEndpoint.create(// The endpoint class
clazz, // we do not want JAXWS to process @HandlerChain
false, // the invoker
new EjbInvokerImpl(clazz, invoker, webServiceEndpointServant, wsCtxt), // the service QName
endpoint.getServiceName(), // the port
endpoint.getWsdlPort(), container, // Derive binding
binding, // primary WSDL
primaryWsdl, // Collection of imported WSDLs and schema
docs, catalogURL);
String uri = endpoint.getEndpointAddressUri();
String urlPattern = uri.startsWith("/") ? uri : "/" + uri;
// All set; Create the adapter
if (adapterList == null) {
adapterList = new ServletAdapterList();
}
adapter = adapterList.createAdapter(endpoint.getName(), urlPattern, wsep);
handlersConfigured = true;
} catch (Throwable t) {
LogHelper.log(logger, Level.SEVERE, LogUtils.CANNOT_INITIALIZE, t, endpoint.getName());
adapter = null;
}
}
}
// set it using this method
synchronized (this) {
addWSContextInfo(wsCtxt);
if (inv != null && inv instanceof EJBInvocation) {
EJBInvocation ejbInv = (EJBInvocation) inv;
ejbInv.setWebServiceContext(wsCtxt);
}
}
adapterInvInfo.setAdapter(adapter);
return adapterInvInfo;
}
use of org.glassfish.internal.data.ApplicationRegistry in project Payara by payara.
the class InstallerThread method load.
/**
* <p> Load the Admin Console web application.</p>
*/
private void load() {
ApplicationRegistry appRegistry = habitat.<ApplicationRegistry>getService(ApplicationRegistry.class);
ApplicationInfo appInfo = appRegistry.get(AdminConsoleAdapter.ADMIN_APP_NAME);
if (appInfo != null && appInfo.isLoaded()) {
// Application is already loaded
adapter.setStateMsg(AdapterState.APPLICATION_LOADED);
return;
}
// hook for Jerome
Application config = adapter.getConfig();
if (config == null) {
throw new IllegalStateException("Admin Console application has no system app entry!");
}
// Set adapter state
adapter.setStateMsg(AdapterState.APPLICATION_LOADING);
// Load the Admin Console Application
String sn = env.getInstanceName();
// FIXME: An exception may not be thrown... check for errors!
ApplicationRef ref = domain.getApplicationRefInServer(sn, AdminConsoleAdapter.ADMIN_APP_NAME);
Deployment lifecycle = habitat.getService(Deployment.class);
for (Deployment.ApplicationDeployment depl : habitat.getService(ApplicationLoaderService.class).processApplication(config, ref)) {
lifecycle.initialize(depl.appInfo, depl.appInfo.getSniffers(), depl.context);
}
// Set adapter state
adapter.setStateMsg(AdapterState.APPLICATION_LOADED);
}
Aggregations