Tech

MongoDB CDR

Published on:

August 19, 2015

Thus the move with MongoDB. Although it is latest technology (and maybe just because of that), writing natively into the database was actually relatively simple. MongoDB can deal with very large amounts of data, so the PBX does not have to bother with it. Down the road we might be even able to use the DB for reading as well, e.g. when the user is using the call history from the web interface.

Moving from CPE deployments to hosted PBX does not only put additional stress on the overall stability of the system; it also adds a lot more call data records (CDR) to be stored. Our old approach to store the CDR locally in our own little database was good for a few thousands records. However as we go forward, we are hitting the millions of records.

A simple, file based database cannot handle that any more.http://vodia.com/documentation/cdr is like a history book on CDR. Originally we started with SOAP, which was at the time a kind of cool technology especially because it was sent using HTTP—a kind of waste at the time. Due to industry demands we added the TCP-based simple CDR, a primitive technology that came from the RS-232 times with lots of problems with the field lengths and special characters.

With the increasing popularity of REST and JSON we added a JSON-based record that was again based on HTTP, which was already pretty cool. However there was still glue logic necessary to store the records in a database. Thus the move with MongoDB. Although it is latest technology (and maybe just because of that), writing natively into the database was actually relatively simple. MongoDB can deal with very large amounts of data, so the PBX does not have to bother with it. Down the road we might be even able to use the DB for reading as well, e.g. when the user is using the call history from the web interface.

To use the new feature, you need to set up the MongoDB on a server. If you set it up on the same machine, things are simple; by default connections coming from the localhost port don’t require any additional setup. If you run the DB on a separate server, you must make sure that the authorization is set up properly; you don’t want just anybody have access to your CDR. The PBX does not support authentication mechanisms for MongoDB or even encryption. It is your responsibility to make sure that only the PBX can access the database.

The schema for the URL is like this: “mongodb://server:port/database/table”. The server must be an IP address or “localhost” for the loopback address “127.0.0.1”. The port defaults to 27019 which is currently the standard MongoDB port; however we recommend to explicitly specify the port. The database string tells the server where to store the CDR; this string may contain the variable “{domain}” which is replaced with the name of the domain. The table name is a string that tells the PBX where to store the CDR. The feature will be available in 5.3. Those who can’t wait can try select 5.2.7 builds which also have it compiled in already.

Latest Articles

View All

Rethinking Communication in Education: Vodia Smart School

Digital communication is now woven into daily school life, from classroom platforms to how parents and teachers connect. Vodia Smart School takes this further with a VoIP-powered system that provides fast, secure, and documented communication for consent forms, sick notes, and routine notifications. In urgent situations, it enables automated alerts to staff, parents, and first responders, ensuring rapid responses when time is critical. Fully GDPR-compliant and offering features such as caller ID masking, MS Teams integration, and control of bells, announcements, and school systems, Smart School gives schools a modern, reliable alternative to legacy systems while improving both safety and everyday operations.

August 28, 2025

Vodia Now Integrates with Microsoft Teams Presence

Vodia PBX now supports Microsoft Teams Presence, building on its Teams Direct Routing certification and Dynamics 365 integration. Using Graph API from version 69.5.13, a user’s Vodia extension is automatically set to Do Not Disturb when they are on a Teams call. Presence status such as Available, Away, Busy, In a Meeting, or Presenting is matched via the Teams user’s principal username or email, allowing VoIP phones and web portals to show real-time status across devices. This integration connects Teams with a full-featured SIP-compliant PBX, enabling organizations to unify communications, streamline workflows, and support both cloud and on-premise telephony solutions.

August 25, 2025

Why Browser Calling is the Future of Business Communication

Vodia’s browser calling solution allows businesses to make and receive VoIP calls directly from any web browser, eliminating the need for apps or desk phones. It offers convenience, cost savings, and a wide range of features including chat, voicemail, call transfers, conference calls, video calls, and CRM integration. The system is secure, operating entirely within the browser to reduce exposure to malware, and scalable to support remote and hybrid work environments. With easy setup through the Vodia PBX web interface, organizations can streamline communication, improve productivity, and provide employees with a flexible, reliable, and fully integrated business communication experience.

August 13, 2025