Package com.uc4.communication
Class Connection
java.lang.Object
com.uc4.communication.Connection
- All Implemented Interfaces:
- AEConnection,- Closeable,- AutoCloseable
This class represents a connection to the UC4 Server with a specific UC4 user.
 
Using the UC4.ApplicationInterface includes this steps:
- Open a connection to the UC4 Server. This is done using the static
     openmethod.
- Login to the UC4 Server using the method
     login. The methodisLoginSuccessfulshould be used to test if the login was successful.
- Send requests using sendRequestAndWaitorsendRequest.
- Close the connection with close.
- 
Method SummaryModifier and TypeMethodDescriptionvoidAdds a close event listener.voidAdds a kick event listener.voidAdds a notification listener.voidclose()Closes the connection to the UC4 Server.Deprecated.There is no CP list in version 21.0 and higherReturns the address of the Java communication processReturns information about the current UC4 Session.intReturns the timeout for synchronous application.Returns the listener of trace message ornullif the trace is not enabled.booleanisValid()Returns true if there is an open connection to the AESets the session, this method must be called before a login request is sent.Sets the session, this method must be called before a login request is sent.Sets the session, this method must be called before a login request is sent.login(AccessTokenConfiguration config) Login using an access tokenlogin(SamlConfiguration config) Single Sign On using SAMLlogin(SSOConfiguration config) Single Sign On (Kerberos) using the current OS user.static ConnectionOpens a connection to the UC4 Server.static Connectionopen(String servername, int port, Properties options) Opens a connection to the UC4 Server.static Connectionopen(String servername, int port, Properties options, DebugAndTraceListener traceListener) Opens a connection to the UC4 Server.static Connectionopen(String servername, int port, Properties options, DebugAndTraceListener traceListener, String trustedCertFolderPath) Opens a connection to the UC4 Server.voidRemoves a close event listener.voidRemoves a notification listener.voidRemoves a notification listener.sendRequest(XMLRequest sendableMessage, IResponseHandler handler) Sends an message to the UC4 Server.voidsendRequestAndWait(XMLRequest sendableMessage) Sends a message to the UC4 Server and waits for the response.voidsetClientType(String clientType) voidsetTimeout(int millis) Sets the timeout in milliseconds.voidsetTraceListener(TraceListener listener) Sets a listener in order to trace the messages that are exchanged between the Automation Engine and the UC4.Application Interface.static voidsetTrustedCertFolderPath(String trustedCertFolderPath) Sets the path to a trusted certificate folder.static voidsetUseTrustedCertFolderOnly(boolean useTrustedCertFolderOnly) Determines wether the certificates in the trusted cert folder should be pinned or nottoString()
- 
Method Details- 
setTrustedCertFolderPathSets the path to a trusted certificate folder. This path will be used for opening connections.- Parameters:
- trustedCertFolderPath- path to a folder containing trusted certificates
 
- 
setUseTrustedCertFolderOnlypublic static void setUseTrustedCertFolderOnly(boolean useTrustedCertFolderOnly) Determines wether the certificates in the trusted cert folder should be pinned or not- Parameters:
- useTrustedCertFolderOnly- true - pinned, false - not
 
- 
setTimeoutpublic void setTimeout(int millis) Sets the timeout in milliseconds. Use zero to disable the timeout.- Parameters:
- millis- Timeout
 
- 
getTimeoutpublic int getTimeout()Returns the timeout for synchronous application.- Returns:
- timeout in milliseconds
 
- 
openOpens a connection to the UC4 Server.- Parameters:
- servername- Name of the Java Communication Process (JCP)
- port- WebSocket Port number of the JCP
- Returns:
- UC4 Connection
- Throws:
- IOException- if an I/O error occurred
 
- 
openOpens a connection to the UC4 Server.- Parameters:
- servername- Name of the Java Communication Process (JCP)
- port- WebSocket Port number of the JCP
- options- Advanced connection options, can be- null. Supported parameters:- Key - Description - AGENTNAME - Name of the Agent if the connection is created within an UC4 Agent process - HOSTNAME - Name of the user's host. This value will be shown in the system overview - REMOTE_ID - Remote ID. This value will be shown in the system overview - SECRET_TYPE - Optional: Type of the secret in the login method. Values: "ET" (Exit-Token), "TK" (AE-Token) and "PW" (Password) - CONNECT_TIMEOUT_MILLIS - Optional: Timeout for the initial connection to the JCP in milliseconds 
- Returns:
- UC4 Connection
- Throws:
- IOException- if an I/O error occurred
 
- 
openpublic static Connection open(String servername, int port, Properties options, DebugAndTraceListener traceListener) throws IOException Opens a connection to the UC4 Server.- Parameters:
- servername- Name of the Java Communication Process (JCP)
- port- WebSocket Port number of the JCP
- options- Advanced connection options, can be- nullSupported parameters:- Key - Description - AGENTNAME - Name of the Agent if the connection is created within an UC4 Agent process - HOSTNAME - Name of the user's host. This value will be shown in the system overview - REMOTE_ID - Remote ID. This value will be shown in the system overview - SECRET_TYPE - Optional: Type of the secret in the login method. Values: "ET" (Exit-Token), "TK" (AE-Token) and "PW" (Password) - CONNECT_TIMEOUT_MILLIS - Optional: Timeout for the initial connection to the JCP in milliseconds 
- traceListener- a- DebugAndTraceListenerfor tracing information regarding the connection
- Returns:
- UC4 Connection
- Throws:
- IOException- if an I/O error occurred
 
- 
openpublic static Connection open(String servername, int port, Properties options, DebugAndTraceListener traceListener, String trustedCertFolderPath) throws IOException Opens a connection to the UC4 Server.- Parameters:
- servername- Name of the Java Communication Process (JCP)
- port- WebSocket Port number of the JCP
- options- Advanced connection options, can be- nullSupported parameters:- Key - Description - AGENTNAME - Name of the Agent if the connection is created within an UC4 Agent process - HOSTNAME - Name of the user's host. This value will be shown in the system overview - REMOTE_ID - Remote ID. This value will be shown in the system overview - SECRET_TYPE - Optional: Type of the secret in the login method. Values: "ET" (Exit-Token), "TK" (AE-Token) and "PW" (Password) - CONNECT_TIMEOUT_MILLIS - Optional: Timeout for the initial connection to the JCP in milliseconds 
- traceListener- a- DebugAndTraceListenerfor tracing information regarding the connection
- trustedCertFolderPath- path to folder containing trusted certificates. If- null, the previously path set by- setTrustedCertFolderPath(String)is used
- Returns:
- UC4 Connection
- Throws:
- IOException- if an I/O error occurred
 
- 
addNotificationListenerAdds a notification listener.- Parameters:
- l- Listener
 
- 
removeNotificationListenerRemoves a notification listener.- Parameters:
- l- Listener
 
- 
addKickEventListenerAdds a kick event listener.- Parameters:
- l- Listener
 
- 
removeKickEventListenerRemoves a notification listener.- Parameters:
- l- Listener
 
- 
addCloseEventListenerAdds a close event listener.- Parameters:
- l- Listener
 
- 
removeCloseEventListenerRemoves a close event listener.- Parameters:
- l- Listener
 
- 
closeCloses the connection to the UC4 Server.- Specified by:
- closein interface- AutoCloseable
- Specified by:
- closein interface- Closeable
- Throws:
- IOException- If an I/O error occurred
 
- 
sendRequestAndWaitSends a message to the UC4 Server and waits for the response. This method blocks until the response from the UC4 Server is arrived. The API connection is closed if the Thread is interrupted while waiting for a response. Throws TimeoutException if a timeout has been set and the Server did not respond within that time.When a request is sent with this method, before further processing of the response, the message of the response (see XMLRequest.getMessageBox()) has to be always checked for any error. Only if this is empty the processing of the response can continue.
 If an error is present, proper error handling has to be implemented on the calling side.
 Processing the unsuccessful response might get undefined results!- Specified by:
- sendRequestAndWaitin interface- AEConnection
- Parameters:
- sendableMessage- XML request
- Throws:
- IOException- If an I/O error occurs
- TimeoutException- if a timeout was defined and a response was not received in the API within the specified time
 
- 
sendRequestSends an message to the UC4 Server.After the request is sent to the UC4 Server the method call returns immediately. When the response to this request arrives the IResponseHandler will be called. This method does not support creating folders (request CreateObject with type FOLD). Use the method sendRequestAndWait() in order to create a new folder.- Specified by:
- sendRequestin interface- AEConnection
- Parameters:
- sendableMessage- Object which implements the- XMLRequestInterface
- handler- Response Handler
- Returns:
- Request Number as String.
- Throws:
- IOException- If an I/O error occurs
 
- 
loginSingle Sign On (Kerberos) using the current OS user. Requires the Java Cryptography Extension (JCE) Unlimited Strength.- Parameters:
- config- SSO configuration containing for example the UC4 client
- Returns:
- CreateSession, the method isLoginSuccessful can be used to test if the login was successful
- Throws:
- IOException- In case of I/O errors
- TimeoutException- if a timeout was defined and a response was not received in the API within the specified time
 
- 
loginSingle Sign On using SAML- Parameters:
- config- configuration containing for example the SAML token or UC4 client
- Returns:
- CreateSessionthe method isLoginSuccessful can be used to test if the login was successful
- Throws:
- IOException- In case of I/O errors
- TimeoutException- if a timeout was defined and a response was not received in the API within the specified time
 
- 
loginLogin using an access token- Parameters:
- config- configuration containing the token
- Returns:
- CreateSessionthe method isLoginSuccessful can be used to test if the login was successful
- Throws:
- IOException- In case of I/O errors
- TimeoutException- if a timeout was defined and a response was not received in the API within the specified time
 
- 
loginSets the session, this method must be called before a login request is sent. ThrowsIllegalArgumentExceptionif the client is out of client number range (0-9999). ThrowsNullPointerExceptionif the username isnull.- Parameters:
- client- must be between 0 and 9999
- department- department may be- null
- kicks- Comma separated list of kick messages.
- Returns:
- CreateSession, the method isLoginSuccessful can be used to test if the login was successful
- Throws:
- IOException- In case of I/O errors
- TimeoutException- if a timeout was defined and a response was not received in the API within the specified time
 
- 
loginpublic CreateSession login(int client, String user, String department, String password, char language) throws IOException Sets the session, this method must be called before a login request is sent. ThrowsIllegalArgumentExceptionif the client is out of client number range (0-9999). ThrowsNullPointerExceptionif the username isnull.- Parameters:
- client- must be between 0 and 9999
- user- Name of the user
- department- department may be- null
- password- If- null, an empty string is used as password.
- language- Language can be 'D' (German), 'E' (English) and 'F' (French)
- Returns:
- CreateSession, the method isLoginSuccessful can be used to test if the login was successful
- Throws:
- IOException- In case of I/O errors
- TimeoutException- if a timeout was defined and a response was not received in the API within the specified time
 
- 
loginpublic CreateSession login(int client, String user, String department, String password, char language, String kicks) throws IOException Sets the session, this method must be called before a login request is sent. ThrowsIllegalArgumentExceptionif the client is out of client number range (0-9999). ThrowsNullPointerExceptionif the username isnull.- Parameters:
- client- must be between 0 and 9999
- user- Name of the user
- department- department may be- null
- password- If- null, an empty string is used as password.
- language- Language can be 'D' (German), 'E' (English) and 'F' (French)
- kicks- Comma separated list of kick messages.
- Returns:
- CreateSession, the method isLoginSuccessful can be used to test if the login was successful
- Throws:
- IOException- In case of I/O errors
- TimeoutException- if a timeout was defined and a response was not received in the API within the specified time
 
- 
setTraceListenerSets a listener in order to trace the messages that are exchanged between the Automation Engine and the UC4.Application Interface. If you don't intend to dynamically add this listener, consider passing a DebugAndTraceListener to open(). This listener will then also trace information regarding opening the connection.- Parameters:
- listener- Listener or- nullto deactivate the trace
 
- 
getTraceListenerReturns the listener of trace message ornullif the trace is not enabled.- Returns:
- Listener instance or nullif not set
 
- 
setClientType
- 
getCpAddressReturns the address of the Java communication process- Returns:
- the address of the Java communication process
 
- 
getSessionInfoReturns information about the current UC4 Session.- Specified by:
- getSessionInfoin interface- AEConnection
- Returns:
- Session information
 
- 
cpIteratorDeprecated.There is no CP list in version 21.0 and higherThisjava.util.Iteratorcan be used to get all CP Addresses in this UC4 System.- Returns:
- Iterator of InetSocketAddress
 
- 
isValidpublic boolean isValid()Returns true if there is an open connection to the AE- Returns:
- true if the connection is open and can be used to send requests, false otherwise
 
- 
toString
 
-