On this page |
|
📋 What’s about
This scenario occurs if you decide to install the push gateway on the same machine (even if we suggest to use an other machine.
METTERE IMMAGINE
📁 Docker Compose File
Note | ||||
---|---|---|---|---|
In this paragraph we’ll analyse the
|
In the file you will find as directives:
push-gateway for notification system
redis for cache
redisinsight for dashboard
drachtio for the stack SIP. In this case you must consider that in SIP protocol the used default ports are 5060 (for UDP/TCP) and 5061 (for TLS), but on XCALLY the Stack SIP is already present with Asterisk. So for the Stack SIP it’s necessary to insert other ports (a 9999 for UDP/TCP and 9998 for TLS)
Code Block |
---|
command: drachtio --contact "sip:*:9999;transport=udp --external-ip 0.0.0.0"
ports:
- 9999:9999/udp
- 9999:9999 |
)
volumes configuration
logging data for logs file
restart : always = if the container crashes, it automatically restarts
networks section
Requirements
Panel | ||
---|---|---|
| ||
Consider So consider that if you decide to define another drachtio name, port, or secret, these data must also be changed in the variables above.
|
💡 Running the docker-compose.yml File
To run the docker-compose.yml file, follow these steps:
Open a terminal or command prompt as root user, pass to motion user, open /home/motion and create the folder named push-gateway
Download and open the docker-compose.yml file with a text editor. Modify, if necessary, the environment variables published in requirements and update the content file
In the directory where the docker-compose.yml file is located, run the Docker Compose Command to start the containers:
Code Block |
---|
docker compose up -d |
With this command, Docker Compose will start the containers in the background.
Verify Container Startup: to verify the status of the containers, you have to run the command:
Code Block |
---|
docker compose ps |
You can see the 4 containers correctly present
Ensure all services listed in the docker-compose.yml file are running correctly
Access RedisInsight:
RedisInsight is the module installed in the docker compose file to view cache content (it works as cache dashboard).
Once running, you can access the RedisInsight web interface by opening your browser and navigating to:
Code Block |
---|
http://serverIP:5540 |
Info |
---|
As serverIP you need to indicate the IP of the push gateway machine |
By default it is created without database and you need to add it, by inserting
host : redis
use the default port
define the desired alias
you can test connection
Add database
Every time a mobile app is connected, you will see all the keys saved in cache memory
The services are now running and ready to be used. You can interact with the push gateway, the Redis server, and the Drachtio server as required.
🔥 Configure the firewall
It’s necessary to configure the firewall to accept requests arriving on different ports:
9998 for Drachtio TCP/UDP
9999 for Drachtio TLS
10000-20000 for RTP stream to allow the voice connection. These ports are open during the call but they are used by Asterisk only after having negotiated ports with external phones
5540 for RedisInsight: optional if you want to reach the service from the web to view cache dashboard
👥 How to configure Mobile Agents
In this scenario, when you create Mobile Agents in Staff Sectionyou will need to specify your Push Gateway Address with the correct port.
In Staff → Agents → Edit Mobile Agent → Mobile App section → Mobile App Push Gateway you need to specify the push gateway address, that in this case is your IP/XCALLY server address (the same machine you are using) + the specific port used for push gateway (e.g. myxcallyaddress/9999)
Note |
---|
Info |
You need to indicate the public IP of the server. You can retrieve it by launching the command Moreover if you want to use TLS protocol (being a secure protocol that requires a certificate, ) the registered domain must be that of the certificate, so in this field you can apply only the certified domain and not the IP |
. |