UniFi Client Reporting: How to monitor and analyze network activity

Published onby Iron (edited on )

For MSPs and IT businesses, it's crucal to understand the behavior of the clients connected to your network. This goes beyond just monitoring the performance of your UniFi devices.

Detailed client reporting allows you to analyze network usage, track connected devices, and identify potential issues or security risks.

In this blog post, we'll explore how to set up and use UniFi client reporting to get a comprehensive view of your network activity.

Let's get it!

Table of Contents

Why client reporting matters

Client reporting provides several key benefits:

  • Usage insights: Understand how different clients use your network, helping you optimize performance and bandwidth allocation.
  • Security: Identify unauthorized devices and potential security threats.
  • Troubleshooting: Diagnose connectivity issues and ensure a seamless experience for all users.
  • Compliance: Maintain logs and reports for regulatory compliance or internal audits.

Setting up UniFi client reporting

To set up client reporting in UniFi, you'll need to access your UniFi Controller. The Controller provides built-in tools for generating client reports and offers API access for more advanced reporting capabilities.

Step 1: Access the UniFi Controller

Log in to your UniFi Controller via your web browser. The Controller's dashboard provides an overview of your network, including connected devices and clients.

Step 2: Navigate to the 'Clients' section

In the UniFi Controller dashboard, navigate to the "Clients" section. Here, you can see a list of all clients currently connected to your network, along with detailed information such as IP address, MAC address, device type, and data usage.

Generating client reports

The UniFi Controller allows you to generate various client reports directly from the interface. Here's how you can create and customize these reports:

  1. Access client statistics: In the "Clients" section, click on a client to view detailed statistics, including connection history, data usage, and signal strength.

  2. Create custom reports: Use the "Insights" and "Statistics" tabs to generate custom reports based on specific time frames and data points. You can filter by device type, connection status, and data usage.

  3. Export reports: Export the reports to CSV or PDF format for further analysis or sharing. This is useful for keeping records or integrating with other reporting tools.

Using the UniFi API for advanced reporting

For more advanced client reporting, you can leverage the UniFi API to automate data extraction and report generation.

Here’s how to get started:

Step 1: Install required libraries

You’ll need the requests library in Python to interact with the UniFi API. Install it using pip:

pip install requests

Step 2: Authenticate with the UniFi Controller

Use the UniFi API to authenticate and extract data. Below is a Python script example for authentication and data extraction:

import requests

# UniFi Controller details
controller_url = "https://your-controller-url:8443"
username = "your-username"
password = "your-password"
site = "default"

# Login to the UniFi Controller
login_data = {
    "username": username,
    "password": password
}
session = requests.Session()
response = session.post(f"{controller_url}/api/login", json=login_data, verify=False)
if response.status_code != 200:
    raise Exception("Failed to log in to UniFi Controller")
print("Successfully logged in!")

# Function to get data from an endpoint
def get_data(endpoint):
    response = session.get(f"{controller_url}/api/s/{site}/{endpoint}", verify=False)
    return response.json()['data']

# Retrieve client statistics
clients = get_data("stat/sta")

# Print client statistics
for client in clients:
    print(f"MAC: {client['mac']}, IP: {client['ip']}, Download: {client['tx_bytes']/1e6:.2f} MB, Upload: {client['rx_bytes']/1e6:.2f} MB")

# Logout from the UniFi Controller
session.post(f"{controller_url}/api/logout", verify=False)
print("Successfully logged out!")

Step 3: Create automated reports

You can extend the above script to generate automated reports. Here’s an example of how to save the data to a CSV file:

import csv

# Write client statistics to a CSV file
with open('client_report.csv', mode='w', newline='') as file:
    writer = csv.writer(file)
    writer.writerow(['MAC Address', 'IP Address', 'Download (MB)', 'Upload (MB)'])
    for client in clients:
        writer.writerow([
            client['mac'],
            client['ip'],
            client['tx_bytes'] / 1e6,
            client['rx_bytes'] / 1e6
        ])

print("Client report saved to client_report.csv")

Scheduling regular reports

To ensure you always have up-to-date client reports, you can schedule your Python script to run at regular intervals using a scheduling tool like cron on Unix-based systems or Task Scheduler on Windows.

Example cron job

Here’s an example cron job that runs the script daily at midnight:

0 0 * * * /usr/bin/python3 /path/to/your_script.py

Final Thoughts

UniFi client reporting is an essential aspect of network management that provides valuable insights into network usage, security, and performance.

By using the UniFi Controller’s built-in tools and leveraging the API for advanced reporting, you can effectively monitor and analyze client activity on your network.

At UniHosted, we do this for you. We provide fully managed UniFi Controllers with automatic backups, worry-free SSL setup, and with client reporting.

Feel free to give it a spin. Additionally, if you would like me to personally walk you through, you can schedule a meeting using my link.

We host UniFi Controllers in the Cloud

Are you ready to take your UniFi Network to the next level? Deploy a UniFi Cloud Controller in minutes and manage your network from anywhere.

Deploy Now

Free tier available

Get the best support

Join 1660+ customers

No credit card required