- Rey Diaz ([email protected])
- Cisco Unified Communications Manager
- Cisco Jabber
-
OpenJDK 11
-
Apache Maven 3.6.3
-
A working Cisco Unified Communications Manager environment:
-
An CUCM application-user or end-user username/password, with the following roles:
Standard CTI Allow Control of Phones supporting Connected Xfer and conf
Standard CTI Allow Control of Phones supporting Rollover Mode
Standard CTI Enabled
Standard CTI Allow Control of all Devices
-
CTI suported phone devices (i.e. Jabber soft phones), configured with at least one shared directory number.
Note, ensure all internal directory numbers have
Allow Control of Device from CTI
enabled
-
- Make sure you have OpenJDK 11 installed,
java
is available in the path, and$JAVA_HOME
points to the right directory:
$ java -version
openjdk 11.0.8 2020-07-14
OpenJDK Runtime Environment (build 11.0.8+10-post-Ubuntu-0ubuntu120.04)
OpenJDK 64-Bit Server VM (build 11.0.8+10-post-Ubuntu-0ubuntu120.04, mixed mode, sharing)
$ echo $JAVA_HOME
/usr/lib/jvm/java-1.11.0-openjdk-amd64
- Open a terminal and use
git
to clone this repository
git clone https://wwwin-github.cisco.com/gve/VE_DevNet_Jabber_Conference_Initiation_With_Original_User.git
- Open the Java project in Visual Studio Code:
cd GVE_DevNet_Jabber_Custom_Tab_Shared_Lines_Status
code .
-
Edit rename
.env.example
to.env
, and edit to specify environment variable config for the samples you wish to run. -
In
monitorLines.java
on line 22, specify the shared line extensions to monitor by DN. For example:String[] lineDNs = { "5016", "5017"};
Once the project is running, it will start monitoring the shared lines specified in the lineDNs[] array.
Upon a call being created to the CTI route point (885016, line 200 on handler.java) A conference will initiate from 5016 to 4030, and then 5017 will be conferenced in.
- In this project, the 11.5 and 12.5 versions of the JTAPI Java library have been deployed to the project's local Maven repo (in
lib/
), with 12.5 being the configured version.
If you want to use 11.5 (or you deploy another version, as below), modify pom.xml
to specify the desired JTAPI version dependency. Modify <version>
:
<dependency>
<groupId>com.cisco.jtapi</groupId>
<artifactId>jtapi</artifactId>
<version>12.5</version>
</dependency>
- If you want to use another JTAPI version in the project:
-
Download and install/extract the JTAPI plugin from CUCM (Applications / Plugins)
-
From this repository's root, use Maven to deploy the new version of
jtapi.jar
to the local repo. You will need to identify the full path to the newjtapi.jar
installed above:
mvn deploy:deploy-file -DgroupId=com.cisco.jtapi -DartifactId=jtapi -Dversion={version} -Durl=file:./lib -DrepositoryId=local-maven-repo -DupdateReleaseInfo=true -Dfile={/path/to/jtapi.jar}
Note: be sure to update {version} and {/path/to/jtapi.jar} to your actual values
-
JTAPI configuration - e.g. trace log number/size/location and various timeouts - can be configured in
jtapi_config/jtapi.ini
(defined as a resource inpom.xml
) -
As of v12.5, the Cisco
jtapi.jar
does not implement the Java Platform Module System (JPMS). See this issue for more info.
Provided under Cisco Sample Code License, for details see LICENSE
Our code of conduct is available here
See our contributing guidelines here
Please note: This script is meant for demo purposes only. All tools/ scripts in this repo are released for use "AS IS" without any warranties of any kind, including, but not limited to their installation, use, or performance. Any use of these scripts and tools is at your own risk. There is no guarantee that they have been through thorough testing in a comparable environment and we are not responsible for any damage or data loss incurred with their use. You are responsible for reviewing and testing any scripts you run thoroughly before use in any non-testing environment.