CRM/NMS Integrations
Page Purpose
Use this page to choose and configure supported CRM/NMS integrations. Use per-integration pages for specific setup details.
Need definitions for overwrite/persistence terms? See the Glossary.
Most operators use built-in integrations. If you have not selected a deployment path yet, start with Quickstart.
flowchart LR
A[CRM/NMS] --> B[LibreQoS Integration Job]
B --> C[ShapedDevices.csv]
B --> D[network.json]
C --> E[lqos_scheduler]
D --> E
E --> F[Shaping Updates]
E --> G[WebUI Status / Urgent Issues]
Choose Your Integration Path
Path |
Best fit |
Primary source of truth |
|---|---|---|
Built-in integration |
Most operators using supported systems |
CRM/NMS via LibreQoS integration jobs |
Custom source of truth |
Operators with in-house CRM/NMS sync logic |
External generated files ( |
Where in WebUI
Integration defaults/common behavior:
Configuration -> IntegrationsPer-integration configuration fields:
Configuration -> IntegrationsOperational health checks after sync changes:
WebUI -> Scheduler StatusandWebUI -> Urgent IssuesTopology/result validation:
WebUI -> Network Tree OverviewandFlow Globe
Built-In Integrations
Important Overwrite Behavior
When integrations are enabled:
ShapedDevices.csvis typically regenerated by integration sync jobs.network.jsonmay also be overwritten depending on integration settings (for examplealways_overwrite_network_json).Manual edits may be overwritten on the next refresh cycle.
Topology Node ID Support
LibreQoS supports an optional generic "id" field on network.json nodes. This field is intended to carry stable node identifiers from the integration source where possible.
Current behavior:
node IDs are the preferred match key for operator-owned site bandwidth overrides and tree-page node override editing when an ID is present
legacy name-only matching is still supported as a fallback for older data
topology names still need to remain globally unique in
network.json
Integration |
|
Notes |
|---|---|---|
UISP |
Yes |
Real UISP sites/devices export generic |
Splynx |
Yes |
Network sites and AP/site topology nodes export generic |
Sonar |
Yes |
Site and AP topology nodes export generic |
Netzur |
Partial |
Exported only when the upstream zone payload includes a stable zone ID. |
VISP |
No |
Current importer shapes services/devices but does not build topology nodes in |
Powercode |
No |
Current importer does not build topology nodes in |
WISPGate |
No |
Current importer does not build topology nodes from stable upstream topology identifiers. |
Common Client Rate Handling
For built-in integrations that import raw subscriber plan speeds, LibreQoS applies the same shared client-rate rule before writing ShapedDevices.csv:
effective client max rate =
max(plan_rate * bandwidth_overhead_factor, plan_rate * client_bandwidth_multiplier)
Integrations that already ingest effective shaped rates keep those values as-is rather than applying the multiplier a second time.