Ditto .NET Tools are diagnostic tools for Ditto.
These tools are available through NuGet.
For support, please contact Ditto Support ([email protected]).
These tools require you to have an already-initialized Ditto instance. Take a look at the C# Documentation.
Tools are individually shipped under different NuGet packages.
The Presence Viewer displays a mesh graph that allows you to see all connected peers within the mesh and the transport each peer is using to make a connection.
You can use Presence Viewer in your .NET MAUI applications:
- Add the package:
<PackageReference Include="DittoTools.PresenceViewer" Version="1.0.0-alpha.1" />
- Create a blank .NET MAUI Page and reference the Presence Viewer.
Add the namespace definition:
xmlns:presence="clr-namespace:DittoTools.PresenceViewer;assembly=DittoPresenceViewer"
Then simply include the view making sure to properly assign the Ditto instance:
<presence:DittoPresenceViewer
Ditto="{Binding Ditto, Source={x:Reference self}}"/>
Full example:
<?xml version="1.0" encoding="utf-8" ?>
<ContentPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
x:Class="DittoMauiTasksApp.PresenceViewerPage"
xmlns:presence="clr-namespace:DittoTools.PresenceViewer;assembly=DittoPresenceViewer"
x:Name="self"
Shell.PresentationMode="Modal"
Title="PresenceViewerPage">
<ContentPage.ToolbarItems>
<ToolbarItem Text="Close"
Clicked="ToolbarItem_Clicked"/>
</ContentPage.ToolbarItems>
<presence:DittoPresenceViewer
Ditto="{Binding Ditto, Source={x:Reference self}}"/>
</ContentPage>
And the code behind:
using System;
using DittoSDK;
using Microsoft.Maui.Controls;
namespace DittoMauiTasksApp;
public partial class PresenceViewerPage : ContentPage
{
public Ditto Ditto { get; set; }
public PresenceViewerPage(Ditto ditto)
{
this.Ditto = ditto;
InitializeComponent();
}
async void ToolbarItem_Clicked(System.Object sender, System.EventArgs e)
{
await Shell.Current.GoToAsync("//MainPage");
}
}
The Ditto Heartbeat tool allows you to monitor, locally or remotely, the peers in your mesh. It allows you to regularly report data and health of the device.
Configure Heartbeat
These are the values you need to provide to the Heartbeat:
Id
- Unique value that identifies the device.SecondsInterval
- The frequency at which the Heartbeat will scrape the data.Metadata
(optional) - Any metadata you want to attach to this heartbeat.
There is a DittoHeartbeatConfig
struct you can use to construct your configuration.
// Provided with the Heartbeat tool
public class DittoHeartbeatConfig
{
public string Id { get; private set; }
public int SecondsInterval { get; private set; }
public Dictionary<string, object>? Metadata { get; private set; }
}
This tool generates a DittoHeartbeatInfo
object with the given data:
public class DittoHeartbeatInfo
{
public string Id { get; internal set; }
public string Schema { get; internal set; }
public int SecondsInterval { get; internal set; }
public string LastUpdated { get; internal set; }
public string Sdk { get; internal set; }
public int PresenceSnapshotDirectlyConnectedPeersCount { get; internal set; }
public Dictionary<string, object> PresenceSnapshotDirectlyConnectedPeers { get; internal set; }
public Dictionary<string, object>? Metadata { get; internal set; }
public string PeerKey { get; internal set; }
}
You can either check the provided UI in the sample app, or create your own and use the data as you please.
Read data:
var hearbeat = new DittoHeartbeat();
var config = new DittoHeartbeatConfig("<ID>", 10);
heartbeat.StartHeartbeat(ditto, config, (heartbeatInfo) => {
// use data
});
The Ditto Tools Example App included in this repo allows you to try the DittoDotnetTools in a standalone .NET MAUI app.