RS.Fritz.Manager.API 2.1.0-alpha0032

This is a prerelease version of RS.Fritz.Manager.API.
There is a newer version of this package available.
See the version list below for details.
dotnet add package RS.Fritz.Manager.API --version 2.1.0-alpha0032
                    
NuGet\Install-Package RS.Fritz.Manager.API -Version 2.1.0-alpha0032
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="RS.Fritz.Manager.API" Version="2.1.0-alpha0032" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="RS.Fritz.Manager.API" Version="2.1.0-alpha0032" />
                    
Directory.Packages.props
<PackageReference Include="RS.Fritz.Manager.API" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add RS.Fritz.Manager.API --version 2.1.0-alpha0032
                    
#r "nuget: RS.Fritz.Manager.API, 2.1.0-alpha0032"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package RS.Fritz.Manager.API@2.1.0-alpha0032
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=RS.Fritz.Manager.API&version=2.1.0-alpha0032&prerelease
                    
Install as a Cake Addin
#tool nuget:?package=RS.Fritz.Manager.API&version=2.1.0-alpha0032&prerelease
                    
Install as a Cake Tool

RS.Fritz.Manager

Allows FritzBox device detection, monitoring, configuring and network traffic capturing. The TR-064 implementation is using pure WCF Soap calls.

Available as a standalone Windows application (UI) and as a NuGet package (API).

For a list of implemented services check the Service implementation status

RS.Fritz.Manager.UI

A Windows .NET WPF application for x64 and ARM64.

Screenshot 2022-03-19 210434

Usage Instructions

  1. Click Discover Internet Gateway Devices
  2. Select a detected device
  3. Select a detected user
  4. Enter the selected user's password
  5. Click Login
  6. Use the Device Information tab to see device details

RS.Fritz.Manager.API

A NuGet package to manage FritzBox devices using pure WCF calls.

Usage Examples

using System.Net;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using RS.Fritz.Manager.API;

// Register the Fritz services in the dependency container using AddFritzApi()
using IHost host = Host.CreateDefaultBuilder(args)
    .ConfigureServices((_, services) => services.AddFritzApi())
    .Build();

using IServiceScope serviceScope = host.Services.CreateScope();

// Search for routers and take the first one
IDeviceSearchService deviceSearchService = serviceScope.ServiceProvider.GetRequiredService<IDeviceSearchService>();
InternetGatewayDevice device = (await deviceSearchService.GetDevicesAsync()).First();

// Show the device model from UPnP data
Console.WriteLine($"Device model: {device.UPnPDescription.Device.ModelDescription}");

// Initialize the device for TR-064, retrieves the security port and the users
await device.InitializeAsync();

// Provide the password for the last logged on user
string lastUsedUserName = device.Users.Single(q => q.LastUser).Name;
Console.WriteLine($"Enter password for {lastUsedUserName}:");
device.NetworkCredential = new NetworkCredential(lastUsedUserName, Console.ReadLine());

// TR-064 example; show the device uptime from the TR-064 DeviceInfo service
DeviceInfoGetInfoResponse deviceInfo = await device.DeviceInfoGetInfoAsync();
Console.WriteLine($"Device uptime: {TimeSpan.FromSeconds(deviceInfo.Uptime)}");

// Special services

// Retrieving the device users manually
IUsersService usersService = serviceScope.ServiceProvider.GetRequiredService<IUsersService>();
IEnumerable<User> users = await usersService.GetUsersAsync(device);
users.ToList().ForEach(q => Console.WriteLine($"User: {q.Name}"));

// Retrieving a list of device hosts in the network
IDeviceHostsService deviceHostsService = serviceScope.ServiceProvider.GetRequiredService<IDeviceHostsService>();
DeviceHostInfo deviceHostInfo = await deviceHostsService.GetDeviceHostsAsync(device);
deviceHostInfo.DeviceHosts.ToList().ForEach(q => Console.WriteLine($"Device host: {q.HostName}"));

// Retrieving a list of mesh hosts in the network
IDeviceMeshService deviceMeshService = serviceScope.ServiceProvider.GetRequiredService<IDeviceMeshService>();
DeviceMeshInfo deviceMeshInfo = await deviceMeshService.GetDeviceMeshAsync(device);
deviceMeshInfo.DeviceMesh.Nodes.ToList().ForEach(q => Console.WriteLine($"Mesh host: {q.DeviceName}"));

// Retrieve a new session for use in the WebUI
IWebUiService webUiService = serviceScope.ServiceProvider.GetRequiredService<IWebUiService>();
WebUiSessionInfo webUiSessionInfo = await webUiService.LogonAsync(device);
Console.WriteLine($"Session: {webUiSessionInfo.Sid}");

// Capture live network traffic from router to file
ICaptureControlService captureControlService = serviceScope.ServiceProvider.GetRequiredService<ICaptureControlService>();
Task.Run(() => StopCaptureAfter1SecondsAsync(device, captureControlService));
FileInfo fileInfo = await captureControlService.GetStartCaptureResponseAsync(device, "c:\\temp", "capturefile");
Console.WriteLine($"Network trace written to file: {fileInfo}");

await host.RunAsync();

static async Task StopCaptureAfter1SecondsAsync(InternetGatewayDevice device, ICaptureControlService captureControlService)
{
    await Task.Delay(1000);
    await captureControlService.GetStopCaptureResponseAsync(device);
}

TR-064 Service implementation status

WAN

  • 🔶 urn:dslforum-org:service:WANIPConnection:1
    • ✅ GetInfo
    • ✅ GetConnectionTypeInfo
    • ❌ SetConnectionType
    • ✅ GetStatusInfo
    • ✅ GetNATRSIPStatus
    • ❌ SetConnectionTrigger
    • ❌ ForceTermination
    • ❌ RequestConnection
    • ✅ X_GetDNSServers
    • ✅ GetPortMappingNumberOfEntries
    • ✅ GetGenericPortMappingEntry
    • ❌ GetSpecificPortMappingEntry
    • ❌ AddPortMapping
    • ❌ DeletePortMapping
    • ✅ GetExternalIPAddress
    • ❌ SetRouteProtocolRx
    • ❌ SetIdleDisconnectTime
  • 🔶 urn:dslforum-org:service:WANPPPConnection:1
    • ✅ GetInfo
    • ✅ GetConnectionTypeInfo
    • ❌ SetConnectionType
    • ✅ GetStatusInfo
    • ✅ GetLinkLayerMaxBitRates
    • ✅ GetUserName
    • ❌ SetUserName
    • ❌ SetPassword
    • ✅ GetNATRSIPStatus
    • ❌ SetConnectionTrigger
    • ❌ ForceTermination
    • ❌ RequestConnection
    • ✅ X_GetDNSServers
    • ✅ GetPortMappingNumberOfEntries
    • ✅ GetGenericPortMappingEntry
    • ❌ GetSpecificPortMappingEntry
    • ❌ AddPortMapping
    • ❌ DeletePortMapping
    • ✅ GetExternalIPAddress
    • ❌ SetRouteProtocolRx
    • ❌ SetIdleDisconnectTime
    • ✅ X_AVM_DE_GetAutoDisconnectTimeSpan
    • ❌ X_AVM_DE_SetAutoDisconnectTimeSpan
  • ✅ urn:dslforum-org:service:WANCommonInterfaceConfig:1
    • ✅ GetCommonLinkProperties
    • ✅ GetTotalBytesSent
    • ✅ GetTotalBytesReceived
    • ✅ GetTotalPacketsSent
    • ✅ GetTotalPacketsReceived
    • ✅ X_AVM-DE_SetWANAccessType
    • ✅ X_AVM-DE_GetOnlineMonitor
  • ✅ urn:dslforum-org:service:WANEthernetLinkConfig:1
    • ✅ GetEthernetLinkStatus
  • ✅ urn:dslforum-org:service:WANDSLInterfaceConfig:1
    • ✅ GetInfo
    • ✅ GetStatisticsTotal
    • ✅ X_AVM-DE_GetDSLDiagnoseInfo
    • ✅ X_AVM-DE_GetDSLInfo
  • 🔶 urn:dslforum-org:service:WANDSLLinkConfig:1
    • ✅ GetInfo
    • ❌ SetEnable
    • ❌ SetDSLLinkType
    • ✅ GetDSLLinkInfo
    • ❌ SetDestinationAddress
    • ✅ GetDestinationAddress
    • ❌ SetATMEncapsulation
    • ✅ GetATMEncapsulation
    • ✅ GetAutoConfig
    • ✅ GetStatistics
  • 🔶 urn:dslforum-org:service:X_AVM-DE_Speedtest:1
    • ✅ GetInfo
    • ❌ SetConfig
  • ❌ urn:dslforum-org:service:X_AVM-DE_RemoteAccess:1
  • ❌ urn:dslforum-org:service:X_AVM-DE_MyFritz:1
  • ❌ urn:dslforum-org:service:X_AVM-DE_HostFilter:1
  • 🔶 urn:dslforum-org:service:Layer3Forwarding:1
    • ❌ SetDefaultConnectionService
    • ✅ GetDefaultConnectionService
    • ✅ GetForwardNumberOfEntries
    • ❌ AddForwardingEntry
    • ❌ DeleteForwardingEntry
    • ❌ GetSpecificForwardingEntry
    • ✅ GetGenericForwardingEntry
    • ❌ SetForwardingEntryEnable

Telephony

  • ❌ urn:dslforum-org:service:X_AVM-DE_OnTel:1
  • ❌ urn:dslforum-org:service:X_AVM-DE_TAM:1
  • ❌ urn:dslforum-org:service:X_VoIP:1

Home network

  • 🔶 urn:dslforum-org:service:Hosts:1
    • ✅ GetHostNumberOfEntries
    • ❌ GetSpecificHostEntry
    • ✅ GetGenericHostEntry
    • ✅ X_AVM-DE_GetChangeCounter
    • ❌ X_AVM-DE_GetAutoWakeOnLANByMACAddress
    • ❌ X_AVM-DE_SetAutoWakeOnLANByMACAddress
    • ❌ X_AVM-DE_SetHostNameByMACAddress
    • ❌ X_AVM-DE_WakeOnLANByMACAddress
    • ❌ X_AVM-DE_GetSpecificHostEntryByIp
    • ❌ X_AVM-DE_HostsCheckUpdate
    • ❌ X_AVM-DE_HostDoUpdate
    • ✅ X_AVM-DE_GetHostListPath
    • ✅ X_AVM-DE_GetMeshListPath
  • ❌ urn:dslforum-org:service:WLANConfiguration:1
  • ❌ urn:dslforum-org:service:LANHostConfigManagement:1
  • 🔶 urn:dslforum-org:service:LANEthernetInterfaceConfig:1
    • ❌ SetEnable
    • ✅ GetInfo
    • ✅ GetStatistics
  • ❌ urn:dslforum-org:service:X_AVM-DE_Dect:1
  • ❌ urn:dslforum-org:service:X_AVM-DE_Homeauto:1
  • ❌ urn:dslforum-org:service:X_AVM-DE_Homeplug:1

Storage/NAS

  • ❌ urn:dslforum-org:service:X_AVM-DE_Storage:1
  • ❌ urn:dslforum-org:service:X_AVM-DE_UPnP:1
  • ❌ urn:dslforum-org:service:X_AVM-DE_Filelinks:1

System

  • ✅ urn:dslforum-org:service:DeviceInfo:1
    • ✅ GetInfo
    • ✅ SetProvisioningCode
    • ✅ GetDeviceLog
    • ✅ GetSecurityPort
  • ❌ urn:dslforum-org:service:DeviceConfig:1
  • ✅ urn:dslforum-org:service:LANConfigSecurity:1
    • ✅ GetInfo
    • ✅ X_AVM-DE_GetAnonymousLogin
    • ✅ X_AVM-DE_GetCurrentUser
    • ✅ SetConfigPassword
    • ✅ X_AVM-DE_GetUserList
  • ❌ urn:dslforum-org:service:X_AVM-DE_AppSetup:1
  • ❌ urn:dslforum-org:service:X_AVM-DE_Auth:1
  • ❌ urn:dslforum-org:service:Time:1
  • ❌ urn:dslforum-org:service:UserInterface:1
Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 is compatible.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
2.8.1 192 1/15/2025
2.8.0 152 1/8/2025
2.7.8 180 1/4/2025
2.7.7 174 1/1/2025
2.7.5 177 1/1/2025
2.5.1 186 12/15/2024
2.5.0-alpha0008 127 5/19/2024
2.5.0-alpha0004 165 3/22/2024
2.5.0-alpha0001 159 1/30/2024
2.5.0-alpha.15 87 12/15/2024
2.4.0 311 1/5/2024
2.4.0-alpha0090 155 1/5/2024
2.4.0-alpha0075 168 12/14/2023
2.4.0-alpha0061 206 6/23/2023
2.4.0-alpha0048 221 6/4/2023
2.4.0-alpha0036 217 5/19/2023
2.4.0-alpha0028 151 4/15/2023
2.4.0-alpha0021 177 2/21/2023
2.4.0-alpha0015 182 1/27/2023
2.4.0-alpha0010 183 1/27/2023
2.4.0-alpha0006 184 1/25/2023
2.4.0-alpha0003 176 1/25/2023
2.4.0-alpha0001 186 1/24/2023
2.3.0 274 1/24/2023
2.3.0-alpha0061 199 1/22/2023
2.3.0-alpha0049 184 1/19/2023
2.3.0-alpha0038 177 1/18/2023
2.3.0-alpha0028 232 1/16/2023
2.3.0-alpha0021 240 11/19/2022
2.3.0-alpha0015 194 10/28/2022
2.3.0-alpha0010 238 7/9/2022
2.3.0-alpha0006 221 5/11/2022
2.3.0-alpha0003 224 4/13/2022
2.3.0-alpha0001 214 4/12/2022
2.2.0 303 4/12/2022
2.2.0-alpha0131 218 4/12/2022
2.2.0-alpha0107 210 4/12/2022
2.2.0-alpha0084 211 4/8/2022
2.2.0-alpha0066 216 4/7/2022
2.2.0-alpha0050 216 4/7/2022
2.2.0-alpha0036 226 4/7/2022
2.2.0-alpha0023 212 4/6/2022
2.2.0-alpha0011 208 4/5/2022
2.2.0-alpha0003 216 4/4/2022
2.1.0 230 4/4/2022
2.1.0-alpha0316 217 4/4/2022
2.1.0-alpha0274 228 4/3/2022
2.1.0-alpha0234 223 4/1/2022
2.1.0-alpha0198 214 3/30/2022
2.1.0-alpha0168 208 3/28/2022
2.1.0-alpha0140 208 3/28/2022
2.1.0-alpha0114 213 3/28/2022
2.1.0-alpha0090 211 3/27/2022
2.1.0-alpha0068 215 3/27/2022
2.1.0-alpha0048 214 3/26/2022
2.1.0-alpha0032 210 3/25/2022
2.1.0-alpha0019 224 3/25/2022
2.1.0-alpha0008 214 3/24/2022
2.0.0 238 3/22/2022
2.0.0-beta0002 211 3/22/2022
2.0.0-beta0001 216 3/22/2022
2.0.0-alpha0011 211 3/24/2022
2.0.0-alpha0004 206 3/23/2022
1.1.0-alpha0161 215 3/22/2022
1.1.0-alpha0135 213 3/22/2022
1.1.0-alpha0111 209 3/22/2022
1.1.0-alpha0089 196 3/21/2022
1.1.0-alpha0069 210 3/21/2022
1.1.0-alpha0051 210 3/21/2022
1.1.0-alpha0036 210 3/21/2022
1.1.0-alpha0023 214 3/21/2022
1.1.0-alpha0012 209 3/20/2022
1.1.0-alpha0003 212 3/19/2022
1.1.0-alpha0001 211 3/19/2022
1.0.0 250 3/19/2022
1.0.0-beta0003 212 3/19/2022
1.0.0-beta0002 217 3/19/2022
1.0.0-beta0001 215 3/19/2022
0.2.0-alpha1222 208 3/19/2022
0.2.0-alpha1221 206 3/19/2022
0.2.0-alpha1118 209 3/19/2022
0.2.0-alpha1017 220 3/19/2022
0.2.0-alpha0926 208 3/19/2022
0.2.0-alpha0836 209 3/19/2022
0.2.0-alpha0747 209 3/18/2022
0.2.0-alpha0660 207 3/18/2022
0.2.0-alpha0574 217 3/18/2022
0.2.0-alpha0489 210 3/18/2022
0.2.0-alpha0405 224 3/18/2022
0.2.0-alpha0322 217 3/18/2022
0.2.0-alpha0240 212 3/18/2022
0.2.0-alpha0159 212 3/18/2022
0.2.0-alpha0079 216 3/17/2022
0.1.3 253 3/17/2022
0.1.3-alpha0051 229 3/17/2022
0.1.3-alpha0050 221 3/17/2022
0.1.3-alpha0049 211 3/17/2022
0.1.3-alpha0048 221 3/17/2022
0.1.3-alpha0047 220 3/16/2022
0.1.3-alpha0046 215 3/16/2022
0.1.3-alpha0045 210 3/16/2022
0.1.3-alpha.44 216 3/15/2022
0.1.3-alpha.43 213 3/14/2022
0.1.3-alpha.42 216 3/14/2022
0.1.3-alpha.41 211 3/14/2022
0.1.3-alpha.40 213 3/14/2022
0.1.3-alpha.39 204 3/14/2022
0.1.3-alpha.38 213 3/14/2022
0.1.3-alpha.37 218 3/14/2022
0.1.3-alpha.36 205 3/13/2022
0.1.3-alpha.35 217 3/13/2022
0.1.3-alpha.34 215 3/13/2022
0.1.3-alpha.33 215 3/13/2022
0.1.3-alpha.32 224 3/13/2022
0.1.3-alpha.31 207 3/13/2022
0.1.3-alpha.30 210 3/13/2022
0.1.3-alpha.29 209 3/13/2022
0.1.3-alpha.28 206 3/13/2022
0.1.3-alpha.27 212 3/13/2022
0.1.3-alpha.26 211 3/13/2022
0.1.3-alpha.8 213 3/13/2022
0.1.3-alpha.7 210 3/13/2022
0.1.3-alpha.4 217 3/13/2022
0.1.3-alpha.3 212 3/13/2022
0.1.3-alpha.2 233 3/13/2022
0.1.2 256 3/12/2022
0.1.2-alpha.15 234 3/12/2022
0.1.2-alpha.14 235 3/12/2022
0.1.2-alpha.13 226 3/12/2022
0.1.2-alpha.12 241 3/12/2022
0.1.2-alpha.11 238 3/12/2022
0.1.2-alpha.10 242 3/11/2022
0.1.2-alpha.7 237 3/11/2022
0.1.2-alpha.6 236 3/11/2022
0.1.2-alpha.2 240 3/10/2022
0.1.1 266 3/9/2022
0.1.1-alpha.10 231 3/10/2022
0.1.1-alpha.9 235 3/9/2022
0.1.1-alpha.6 237 3/9/2022
0.1.1-alpha.2 235 3/9/2022
0.1.0 256 3/7/2022
0.1.0-alpha.80 236 3/8/2022
0.1.0-alpha.79 244 3/8/2022
0.1.0-alpha.78 244 3/7/2022
0.1.0-alpha.77 239 3/6/2022
0.1.0-alpha.76 245 3/6/2022
0.1.0-alpha.75 222 3/6/2022
0.1.0-alpha.74 224 3/5/2022
0.1.0-alpha.73 239 3/5/2022
0.1.0-alpha.72 247 3/5/2022