Package jadex.extension.rs.publish
Class AbstractRestPublishService
- java.lang.Object
- 
- jadex.extension.rs.publish.AbstractRestPublishService
 
- 
- All Implemented Interfaces:
- IPublishService,- IWebPublishService
 - Direct Known Subclasses:
- ExternalRestPublishService
 
 public abstract class AbstractRestPublishService extends java.lang.Object implements IWebPublishService Publish service without Jersey directly using different containers (in concrete impls).
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classAbstractRestPublishService.ConversationInfoStruct for storing info about a request and the results.static classAbstractRestPublishService.MappingInfoclassAbstractRestPublishService.ResponseInfoInfo struct for response.static classAbstractRestPublishService.SSEEventSSE event data class.
 - 
Field SummaryFields Modifier and Type Field Description static java.lang.StringASYNC_CONTEXT_INFOAsync context info.protected jadex.platform.service.serialization.serializers.JadexBinarySerializerbinserThe binary processor.protected IInternalAccesscomponentThe component.protected java.util.Map<java.lang.String,AbstractRestPublishService.ConversationInfo>conversationinfosInfo about an ongoing conversation, i.e.protected MultiCollection<java.lang.String,IObjectStringConverter>convertersThe media type converters.static java.lang.StringFINISHEDFinished result marker.static java.lang.StringHEADER_JADEX_CALLFINISHEDHttp header for the call id siganlling that this is the last response (resp).static java.lang.StringHEADER_JADEX_CALLIDHttp header for the call id (req and resp).static java.lang.StringHEADER_JADEX_CLIENTTIMEOUTHttp header for the client side timeout of calls (req).static java.lang.StringHEADER_JADEX_ISLOGGEDINstatic java.lang.StringHEADER_JADEX_LOGINHttp header to login to the platform and gain admin access (req).static java.lang.StringHEADER_JADEX_LOGOUTstatic java.lang.StringHEADER_JADEX_MAXHttp header for max value of intermediate future.static java.lang.StringHEADER_JADEX_TERMINATEHttp header to terminate the call (req).static java.lang.StringHEADER_JADEX_VERSIONHttp header for the Jadex version.protected jadex.platform.service.serialization.serializers.JadexJsonSerializerjsonserThe json processor.protected booleanloginsecLogin security of or off.static java.util.List<java.lang.String>PARAMETER_MEDIATYPESSome basic media types for service invocations.protected java.util.Map<java.lang.String,java.util.Map<java.lang.String,java.lang.Object>>sessionsThe sessions.protected java.util.List<AbstractRestPublishService.SSEEvent>sseeventsSSE events that could not directly be sent.- 
Fields inherited from interface jadex.bridge.service.types.publish.IPublishServiceDEFAULT_RSPUBLISH_COMPONENTS, PUBLISH_RS, PUBLISH_WS
 
- 
 - 
Constructor SummaryConstructors Constructor Description AbstractRestPublishService()
 - 
Method SummaryAll Methods Static Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description voidaddConverter(java.lang.String[] mediatypes, IObjectStringConverter converter)Add a converter for one or multiple types.protected static voidaddEntry(java.util.Map<java.lang.String,java.lang.Object> ret, java.lang.String key, java.lang.Object val)protected voidcomplete(jakarta.servlet.http.HttpServletRequest request, jakarta.servlet.http.HttpServletResponse response)static java.lang.ObjectconvertJsonValue(java.lang.String val, java.lang.Class<?> type, java.lang.ClassLoader cl, boolean tomap)Convert a json string to a java object.java.lang.ObjectconvertParameter(java.lang.Object val, java.lang.Class<?> target)Convert a (string) parameterprotected java.lang.ObjectconvertParameter(java.util.List<java.lang.String> sr, java.lang.String val, java.lang.Class<?> targetclazz)Convert a parameter string to an object if is json or xml.protected AbstractRestPublishService.SSEEventcreateSSEEvent(AbstractRestPublishService.ResponseInfo ri)Create an sse event.protected AbstractRestPublishService.SSEEventcreateSSEEvent(java.lang.Object result, boolean finished, java.lang.String callid, java.lang.Integer max, java.lang.String exceptiontype)Create an sse event.protected java.lang.StringcreateSSEJson(AbstractRestPublishService.SSEEvent event)Create an sse event for a JavaSSE event.IFuture<PathManager<AbstractRestPublishService.MappingInfo>>evaluateMapping(IServiceIdentifier sid, PublishInfo pi)Evaluate the service interface and generate mappings.java.util.Map<java.lang.String,java.lang.String>extractCallerValues(java.lang.Object request)Extract caller values like ip and browser.static java.lang.Object[]generateInParameters(java.util.Map<java.lang.String,java.lang.Object> inparamsmap, Tuple2<java.util.List<Tuple2<java.lang.String,java.lang.String>>,java.util.Map<java.lang.String,java.lang.Class<?>>> pinfos, java.lang.Class<?>[] types)Generate in parameters that are correct wrt order and number of targetparameter (must convert types possibly).protected IAsyncContextInfogetAsyncContextInfo(jakarta.servlet.http.HttpServletRequest request)Get the asyncjava.lang.StringgetCleanPublishId(java.lang.String id)Get the cleaned publish id.abstract java.lang.ObjectgetHttpServer(java.net.URI uri, PublishInfo info)Get or start an api to the http server.Tuple2<java.util.List<Tuple2<java.lang.String,java.lang.String>>,java.util.Map<java.lang.String,java.lang.Class<?>>>getParameterInfos(java.lang.reflect.Method method)Get metainfo about parameters from the target method via annotations.static longgetRequestTimeout(jakarta.servlet.http.HttpServletRequest request)Get the request timeout.java.lang.StringgetServiceInfo(java.lang.Object service, java.lang.String baseuri, PathManager<AbstractRestPublishService.MappingInfo> mappings)Functionality blueprint for get service info web method.static java.lang.StringgetServletHost(jakarta.servlet.http.HttpServletRequest req)Get the servlet base url.static java.lang.StringgetServletUrl(jakarta.servlet.http.HttpServletRequest req)Get the servlet base url.java.util.Map<java.lang.String,java.lang.Object>getSession(jakarta.servlet.http.HttpServletRequest request, boolean create)Get a session.java.util.Map<java.lang.String,java.lang.Object>getSession(java.lang.String sessionid, boolean create)Get a session.java.lang.StringgetSessionId(jakarta.servlet.http.HttpServletRequest request)Get a session id.AbstractRestPublishService.MappingInfo.HttpMethodguessRestType(java.lang.reflect.Method method)Guess the http type (GET, POST, PUT, DELETE, ...) of a method.voidhandleRequest(IService service, PathManager<AbstractRestPublishService.MappingInfo> pm, jakarta.servlet.http.HttpServletRequest request, jakarta.servlet.http.HttpServletResponse response, java.lang.Object[] others)Handle a web request.booleanhasStringConvertableParameters(java.lang.reflect.Method method, java.lang.Class<?> rettype, java.lang.Class<?>[] paramtypes)Test if a method has parameters that are all convertible from string.IFuture<java.lang.Void>init()The service init.protected booleanisComplete(jakarta.servlet.http.HttpServletRequest request, jakarta.servlet.http.HttpServletResponse response)booleanisLoggedIn(jakarta.servlet.http.HttpServletRequest request)Test if a the web user is logged in.IFuture<java.lang.Boolean>isLoggedIn(java.lang.String callid)Test if a the web user is logged in.IFuture<java.lang.Boolean>isSupported(java.lang.String publishtype)Test if publishing a specific type is supported (e.g.java.lang.StringloadFunctionJS()IFuture<byte[]>loadJadexJS()Load jadex.jsjava.lang.StringloadStyleCSS()IFuture<java.lang.Boolean>login(jakarta.servlet.http.HttpServletRequest request, java.lang.String secret)Log in to the platform.IFuture<java.lang.Boolean>logout(jakarta.servlet.http.HttpServletRequest request)Logout from the platform.static voidmain(java.lang.String[] args)protected Tuple2<AbstractRestPublishService.MappingInfo,java.lang.Object[]>mapParameters(jakarta.servlet.http.HttpServletRequest request, java.util.Collection<AbstractRestPublishService.MappingInfo> mis, java.util.List<java.util.Map<java.lang.String,java.lang.String>> bindings)Map the incoming uri/post/multipart parameters to the service target parameter types.protected java.lang.ObjectmapResult(java.lang.reflect.Method method, java.lang.Object ret)Map a result using the result mapper.static java.util.List<java.lang.String>parseMimetypes(java.lang.String mts)todo: make statically accessible Copied from Jadex ForwardFilterabstract IFuture<java.lang.Void>publishService(IServiceIdentifier serviceid, PublishInfo info)Publish a service.voidremoveConverter(java.lang.String[] mediatypes, IObjectStringConverter converter)Remove a converter.protected voidsendDelayedSSEEvents(java.util.Map<java.lang.String,java.lang.Object> session)Send the delayed events which have been collected during connection loss.protected voidsetCORSHeader(jakarta.servlet.http.HttpServletResponse response)Set the cors header in the response.IFuture<java.lang.Void>setLoginSecurity(boolean sec)Turn on or off the login security.protected voidsetNoCachingHeader(jakarta.servlet.http.HttpServletResponse response)Set the cache header in the response.static java.util.Map<java.lang.String,java.lang.Object>splitQueryString(java.lang.String query)Split the query and save the order.protected voidwriteResponse(AbstractRestPublishService.ResponseInfo ri)Write the response (header and content).protected voidwriteResponseContent(AbstractRestPublishService.ResponseInfo ri)Write the response content.protected java.util.List<java.lang.String>writeResponseHeader(AbstractRestPublishService.ResponseInfo ri)- 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface jadex.bridge.service.types.publish.IPublishServiceunpublishService
 - 
Methods inherited from interface jadex.bridge.service.types.publish.IWebPublishServicepublishHMTLPage, publishResources
 
- 
 
- 
- 
- 
Field Detail- 
ASYNC_CONTEXT_INFOpublic static final java.lang.String ASYNC_CONTEXT_INFO Async context info.- See Also:
- Constant Field Values
 
 - 
HEADER_JADEX_VERSIONpublic static final java.lang.String HEADER_JADEX_VERSION Http header for the Jadex version.- See Also:
- Constant Field Values
 
 - 
HEADER_JADEX_CALLIDpublic static final java.lang.String HEADER_JADEX_CALLID Http header for the call id (req and resp).- See Also:
- Constant Field Values
 
 - 
HEADER_JADEX_CALLFINISHEDpublic static final java.lang.String HEADER_JADEX_CALLFINISHED Http header for the call id siganlling that this is the last response (resp).- See Also:
- Constant Field Values
 
 - 
HEADER_JADEX_MAXpublic static final java.lang.String HEADER_JADEX_MAX Http header for max value of intermediate future.- See Also:
- Constant Field Values
 
 - 
HEADER_JADEX_CLIENTTIMEOUTpublic static final java.lang.String HEADER_JADEX_CLIENTTIMEOUT Http header for the client side timeout of calls (req).- See Also:
- Constant Field Values
 
 - 
HEADER_JADEX_TERMINATEpublic static final java.lang.String HEADER_JADEX_TERMINATE Http header to terminate the call (req).- See Also:
- Constant Field Values
 
 - 
HEADER_JADEX_LOGINpublic static final java.lang.String HEADER_JADEX_LOGIN Http header to login to the platform and gain admin access (req).- See Also:
- Constant Field Values
 
 - 
HEADER_JADEX_LOGOUTpublic static final java.lang.String HEADER_JADEX_LOGOUT - See Also:
- Constant Field Values
 
 - 
HEADER_JADEX_ISLOGGEDINpublic static final java.lang.String HEADER_JADEX_ISLOGGEDIN - See Also:
- Constant Field Values
 
 - 
FINISHEDpublic static final java.lang.String FINISHED Finished result marker.- See Also:
- Constant Field Values
 
 - 
PARAMETER_MEDIATYPESpublic static java.util.List<java.lang.String> PARAMETER_MEDIATYPES Some basic media types for service invocations.
 - 
componentprotected IInternalAccess component The component.
 - 
conversationinfosprotected java.util.Map<java.lang.String,AbstractRestPublishService.ConversationInfo> conversationinfos Info about an ongoing conversation, i.e. Jadex future, session etc.
 - 
sseeventsprotected java.util.List<AbstractRestPublishService.SSEEvent> sseevents SSE events that could not directly be sent.
 - 
convertersprotected MultiCollection<java.lang.String,IObjectStringConverter> converters The media type converters.
 - 
loginsecprotected boolean loginsec Login security of or off.
 - 
jsonserprotected jadex.platform.service.serialization.serializers.JadexJsonSerializer jsonser The json processor.
 - 
binserprotected jadex.platform.service.serialization.serializers.JadexBinarySerializer binser The binary processor.
 - 
sessionsprotected java.util.Map<java.lang.String,java.util.Map<java.lang.String,java.lang.Object>> sessions The sessions. Cannot use built-in due to problem with concurrent inital requests (and also after platform restart). Two requests (sse, subscribeX) arrive at server with the same jsessionid -> session not known, server creates a new one for both with different ids. https://community.oracle.com/tech/developers/discussion/1455774/multiple-sessions-created.
 
- 
 - 
Method Detail- 
initpublic IFuture<java.lang.Void> init() The service init.
 - 
getSessionpublic java.util.Map<java.lang.String,java.lang.Object> getSession(jakarta.servlet.http.HttpServletRequest request, boolean create)Get a session.- Parameters:
- request- The request
- create- Flag if shall be created.
- Returns:
- The session.
 
 - 
getSessionpublic java.util.Map<java.lang.String,java.lang.Object> getSession(java.lang.String sessionid, boolean create)Get a session.- Parameters:
- request- The request
- create- Flag if shall be created.
- Returns:
- The session.
 
 - 
getSessionIdpublic java.lang.String getSessionId(jakarta.servlet.http.HttpServletRequest request) Get a session id.- Parameters:
- request- The request
- Returns:
- The session id.
 
 - 
setLoginSecuritypublic IFuture<java.lang.Void> setLoginSecurity(boolean sec) Turn on or off the login security. If true one has to log in with platform secret before using published services.- Specified by:
- setLoginSecurityin interface- IWebPublishService
- Parameters:
- sec- On or off.
 
 - 
addConverterpublic void addConverter(java.lang.String[] mediatypes, IObjectStringConverter converter)Add a converter for one or multiple types.
 - 
removeConverterpublic void removeConverter(java.lang.String[] mediatypes, IObjectStringConverter converter)Remove a converter.- Parameters:
- converter- The converter.
 
 - 
isSupportedpublic IFuture<java.lang.Boolean> isSupported(java.lang.String publishtype) Test if publishing a specific type is supported (e.g. web service).- Specified by:
- isSupportedin interface- IPublishService
- Parameters:
- publishtype- The type to test.
- Returns:
- True, if can be published.
 
 - 
handleRequestpublic void handleRequest(IService service, PathManager<AbstractRestPublishService.MappingInfo> pm, jakarta.servlet.http.HttpServletRequest request, jakarta.servlet.http.HttpServletResponse response, java.lang.Object[] others) throws java.io.IOException, jakarta.servlet.ServletException Handle a web request.- Parameters:
- service- The service.
- mappings- The collected mapping infos for the service.
- request- The request.
- response- The response.
- Throws:
- java.io.IOException
- jakarta.servlet.ServletException
 
 - 
setCORSHeaderprotected void setCORSHeader(jakarta.servlet.http.HttpServletResponse response) Set the cors header in the response.- Parameters:
- response- The response.
 
 - 
setNoCachingHeaderprotected void setNoCachingHeader(jakarta.servlet.http.HttpServletResponse response) Set the cache header in the response.- Parameters:
- response- The response.
 
 - 
sendDelayedSSEEventsprotected void sendDelayedSSEEvents(java.util.Map<java.lang.String,java.lang.Object> session) Send the delayed events which have been collected during connection loss. Must check if callid belongs to still ongoing call (could be terminated).
 - 
publishServicepublic abstract IFuture<java.lang.Void> publishService(IServiceIdentifier serviceid, PublishInfo info) Publish a service.- Specified by:
- publishServicein interface- IPublishService
- Parameters:
- cl- The classloader.
- service- The original service.
- pid- The publish id (e.g. url or name).
 
 - 
getHttpServerpublic abstract java.lang.Object getHttpServer(java.net.URI uri, PublishInfo info)Get or start an api to the http server.
 - 
loginpublic IFuture<java.lang.Boolean> login(jakarta.servlet.http.HttpServletRequest request, java.lang.String secret) Log in to the platform.- Parameters:
- request- The request.
- secret- The platform secret.
- Returns:
- True, if login was successful.
 
 - 
logoutpublic IFuture<java.lang.Boolean> logout(jakarta.servlet.http.HttpServletRequest request) Logout from the platform.- Parameters:
- secret- The platform secret.
- Returns:
- True, if login was successful.
 
 - 
isLoggedInpublic boolean isLoggedIn(jakarta.servlet.http.HttpServletRequest request) Test if a the web user is logged in.- Parameters:
- request- The web request.
- Returns:
- True, if is logged in.
 
 - 
isLoggedInpublic IFuture<java.lang.Boolean> isLoggedIn(java.lang.String callid) Test if a the web user is logged in.- Specified by:
- isLoggedInin interface- IWebPublishService
- Parameters:
- callid- The callid of the request.
- Returns:
- True, if is logged in.
 
 - 
getAsyncContextInfoprotected IAsyncContextInfo getAsyncContextInfo(jakarta.servlet.http.HttpServletRequest request) Get the async
 - 
mapParametersprotected Tuple2<AbstractRestPublishService.MappingInfo,java.lang.Object[]> mapParameters(jakarta.servlet.http.HttpServletRequest request, java.util.Collection<AbstractRestPublishService.MappingInfo> mis, java.util.List<java.util.Map<java.lang.String,java.lang.String>> bindings) Map the incoming uri/post/multipart parameters to the service target parameter types.
 - 
generateInParameterspublic static java.lang.Object[] generateInParameters(java.util.Map<java.lang.String,java.lang.Object> inparamsmap, Tuple2<java.util.List<Tuple2<java.lang.String,java.lang.String>>,java.util.Map<java.lang.String,java.lang.Class<?>>> pinfos, java.lang.Class<?>[] types)Generate in parameters that are correct wrt order and number of targetparameter (must convert types possibly).
 - 
convertJsonValuepublic static java.lang.Object convertJsonValue(java.lang.String val, java.lang.Class<?> type, java.lang.ClassLoader cl, boolean tomap)Convert a json string to a java object.- Parameters:
- val- The json string.
- type- The target class.
- cl- The classloader.
- tomap- Flag, if a (nested) map should be read (only possible if type is map too).
 
 - 
convertParameterpublic java.lang.Object convertParameter(java.lang.Object val, java.lang.Class<?> target)Convert a (string) parameter- Parameters:
- val-
- target-
- Returns:
 
 - 
convertParameterprotected java.lang.Object convertParameter(java.util.List<java.lang.String> sr, java.lang.String val, java.lang.Class<?> targetclazz)Convert a parameter string to an object if is json or xml.- Parameters:
- sr- The media types.
- val- The string value.
- Returns:
- The decoded object.
 
 - 
mapResultprotected java.lang.Object mapResult(java.lang.reflect.Method method, java.lang.Object ret)Map a result using the result mapper.
 - 
writeResponseprotected void writeResponse(AbstractRestPublishService.ResponseInfo ri) Write the response (header and content).
 - 
writeResponseHeaderprotected java.util.List<java.lang.String> writeResponseHeader(AbstractRestPublishService.ResponseInfo ri) 
 - 
writeResponseContentprotected void writeResponseContent(AbstractRestPublishService.ResponseInfo ri) Write the response content.
 - 
createSSEEventprotected AbstractRestPublishService.SSEEvent createSSEEvent(AbstractRestPublishService.ResponseInfo ri) Create an sse event.- Parameters:
- result-
- finished-
- callid-
- max-
- Returns:
 
 - 
createSSEEventprotected AbstractRestPublishService.SSEEvent createSSEEvent(java.lang.Object result, boolean finished, java.lang.String callid, java.lang.Integer max, java.lang.String exceptiontype) Create an sse event.
 - 
createSSEJsonprotected java.lang.String createSSEJson(AbstractRestPublishService.SSEEvent event) Create an sse event for a JavaSSE event.
 - 
getRequestTimeoutpublic static long getRequestTimeout(jakarta.servlet.http.HttpServletRequest request) Get the request timeout.
 - 
parseMimetypespublic static java.util.List<java.lang.String> parseMimetypes(java.lang.String mts) todo: make statically accessible Copied from Jadex ForwardFilter
 - 
splitQueryStringpublic static java.util.Map<java.lang.String,java.lang.Object> splitQueryString(java.lang.String query) throws java.lang.ExceptionSplit the query and save the order.- Throws:
- java.lang.Exception
 
 - 
mainpublic static void main(java.lang.String[] args) throws java.lang.Exception- Throws:
- java.lang.Exception
 
 - 
addEntryprotected static void addEntry(java.util.Map<java.lang.String,java.lang.Object> ret, java.lang.String key, java.lang.Object val)- Parameters:
- ret-
- key-
- val-
 
 - 
evaluateMappingpublic IFuture<PathManager<AbstractRestPublishService.MappingInfo>> evaluateMapping(IServiceIdentifier sid, PublishInfo pi) Evaluate the service interface and generate mappings. Return a multicollection in which for each path name the possible methods are contained (can be more than one due to different parameters).
 - 
getServletUrlpublic static java.lang.String getServletUrl(jakarta.servlet.http.HttpServletRequest req) Get the servlet base url.- Parameters:
- req- The request.
- Returns:
- The servlet base url.
 
 - 
getServletHostpublic static java.lang.String getServletHost(jakarta.servlet.http.HttpServletRequest req) Get the servlet base url.- Parameters:
- req- The request.
- Returns:
- The servlet base url.
 
 - 
getServiceInfopublic java.lang.String getServiceInfo(java.lang.Object service, java.lang.String baseuri, PathManager<AbstractRestPublishService.MappingInfo> mappings)Functionality blueprint for get service info web method. Creates a html page with css for style and javascript for ajax post requests. The service info site contains a section for each published method.- Parameters:
- params- The parameters.
- Returns:
- The result.
 
 - 
loadFunctionJSpublic java.lang.String loadFunctionJS() 
 - 
loadStyleCSSpublic java.lang.String loadStyleCSS() 
 - 
guessRestTypepublic AbstractRestPublishService.MappingInfo.HttpMethod guessRestType(java.lang.reflect.Method method) Guess the http type (GET, POST, PUT, DELETE, ...) of a method.- Parameters:
- method- The method.
- Returns:
- The rs annotation of the method type to use
 
 - 
hasStringConvertableParameterspublic boolean hasStringConvertableParameters(java.lang.reflect.Method method, java.lang.Class<?> rettype, java.lang.Class<?>[] paramtypes)Test if a method has parameters that are all convertible from string.- Parameters:
- method- The method.
- rettype- The return types (possibly unwrapped from future type).
- paramtypes- The parameter types.
- Returns:
- True, if is convertible.
 
 - 
completeprotected void complete(jakarta.servlet.http.HttpServletRequest request, jakarta.servlet.http.HttpServletResponse response)- Parameters:
- request-
- cinfo-
 
 - 
isCompleteprotected boolean isComplete(jakarta.servlet.http.HttpServletRequest request, jakarta.servlet.http.HttpServletResponse response)- Parameters:
- request-
- cinfo-
 
 - 
loadJadexJSpublic IFuture<byte[]> loadJadexJS() Load jadex.js- Returns:
- The text from the file.
 
 - 
getParameterInfospublic Tuple2<java.util.List<Tuple2<java.lang.String,java.lang.String>>,java.util.Map<java.lang.String,java.lang.Class<?>>> getParameterInfos(java.lang.reflect.Method method) Get metainfo about parameters from the target method via annotations.
 - 
extractCallerValuespublic java.util.Map<java.lang.String,java.lang.String> extractCallerValues(java.lang.Object request) Extract caller values like ip and browser.- Parameters:
- request- The requrest.
- vals- The values.
 
 - 
getCleanPublishIdpublic java.lang.String getCleanPublishId(java.lang.String id) Get the cleaned publish id. Square brackets for the optional host and context part are removed.
 
- 
 
-