Added console project
This commit is contained in:
parent
c0544ed179
commit
25f0964b0b
25
StarlinkConnectionTest.sln
Normal file
25
StarlinkConnectionTest.sln
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
|
||||||
|
Microsoft Visual Studio Solution File, Format Version 12.00
|
||||||
|
# Visual Studio Version 17
|
||||||
|
VisualStudioVersion = 17.1.32127.271
|
||||||
|
MinimumVisualStudioVersion = 10.0.40219.1
|
||||||
|
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "StarlinkConnectionTest", "StarlinkConnectionTest\StarlinkConnectionTest.csproj", "{D907657D-3813-4BC2-B4AE-B954D6EA799D}"
|
||||||
|
EndProject
|
||||||
|
Global
|
||||||
|
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||||
|
Debug|Any CPU = Debug|Any CPU
|
||||||
|
Release|Any CPU = Release|Any CPU
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
||||||
|
{D907657D-3813-4BC2-B4AE-B954D6EA799D}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
|
{D907657D-3813-4BC2-B4AE-B954D6EA799D}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
|
{D907657D-3813-4BC2-B4AE-B954D6EA799D}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
|
{D907657D-3813-4BC2-B4AE-B954D6EA799D}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(SolutionProperties) = preSolution
|
||||||
|
HideSolutionNode = FALSE
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(ExtensibilityGlobals) = postSolution
|
||||||
|
SolutionGuid = {E21C4445-1FE8-4614-8FE3-E8547C7815D4}
|
||||||
|
EndGlobalSection
|
||||||
|
EndGlobal
|
102
StarlinkConnectionTest/Program.cs
Normal file
102
StarlinkConnectionTest/Program.cs
Normal file
@ -0,0 +1,102 @@
|
|||||||
|
using System.Net;
|
||||||
|
using System.Net.Http.Headers;
|
||||||
|
using System.Net.Sockets;
|
||||||
|
|
||||||
|
internal class Program
|
||||||
|
{
|
||||||
|
static void Main(string[] args)
|
||||||
|
{
|
||||||
|
PacketReciever pr = new PacketReciever();
|
||||||
|
// This sequence is used to poll either the router (192.168.1.1) or dish (192.168.100.1) for statistics.
|
||||||
|
byte[] statsSequence = new byte[] { 0, 0, 0, 0, 3, 0xE2, 0x3E, 0 };
|
||||||
|
|
||||||
|
Timer t = new(new((x) => pr.Update(statsSequence)), null, 2000, 5000); // Fire at a regular interval
|
||||||
|
Console.ReadLine();
|
||||||
|
}
|
||||||
|
class PacketReciever
|
||||||
|
{
|
||||||
|
readonly HttpClient client;
|
||||||
|
/// <summary>
|
||||||
|
/// List of known data tags
|
||||||
|
/// </summary>
|
||||||
|
static readonly List<byte[]> KnownTags = new()
|
||||||
|
{
|
||||||
|
new byte[] { 0xa5, 0x3f }, // BoresiteElevation
|
||||||
|
new byte[] { 0x9d, 0x3f }, // Boresite Azimuth
|
||||||
|
new byte[] { 0x8d, 0x3f }, // Ping
|
||||||
|
new byte[] { 0x85, 0x3f }, // Upload
|
||||||
|
new byte[] { 0xfd, 0x3e }, // Download
|
||||||
|
//new byte[] { 0xfd, 0x3f }, // Unknown
|
||||||
|
// ??? // Ping loss rate
|
||||||
|
};
|
||||||
|
|
||||||
|
public PacketReciever()
|
||||||
|
{
|
||||||
|
client = new();
|
||||||
|
client.DefaultRequestVersion = HttpVersion.Version11;
|
||||||
|
client.DefaultVersionPolicy = HttpVersionPolicy.RequestVersionOrHigher;
|
||||||
|
}
|
||||||
|
|
||||||
|
public async void Update(byte[] requestContent)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
// Create the request
|
||||||
|
ByteArrayContent content = new(requestContent);
|
||||||
|
// gRPC expects the content type to be a gRPC request, else will not respond with valid data
|
||||||
|
content.Headers.ContentType = MediaTypeHeaderValue.Parse("application/grpc-web+proto");
|
||||||
|
// Send the request
|
||||||
|
HttpResponseMessage r = await client.PostAsync("http://192.168.100.1:9201/SpaceX.API.Device.Device/Handle", content);
|
||||||
|
Console.Clear();
|
||||||
|
Dictionary<string, byte[]> tagValues = new();
|
||||||
|
byte[] data = await r.Content.ReadAsByteArrayAsync();
|
||||||
|
int dataIndex = LastIndexOf(data, new byte[] { 0x67, 0x72, 0x70, 0x63, 0x2D, 0x73, 0x74, 0x61, 0x74, 0x75, 0x73, 0x3A });
|
||||||
|
while (dataIndex > -1) // Search for `grpc-status:`; is the known end of data
|
||||||
|
{
|
||||||
|
// Valid data packet, parse;
|
||||||
|
foreach (var item in KnownTags)
|
||||||
|
{
|
||||||
|
if (data[dataIndex] == item[0] && data[dataIndex + 1] == item[1])
|
||||||
|
{
|
||||||
|
byte[] dataBytes = new byte[] { data[dataIndex+2], data[dataIndex+3], data[dataIndex+4], data[dataIndex+5] };
|
||||||
|
tagValues.Add(string.Format("{0:X}{1:X}", item[0], item[1]), dataBytes);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
dataIndex--;
|
||||||
|
}
|
||||||
|
float download = tagValues.ContainsKey("FD3E") ? BitConverter.ToSingle(tagValues["FD3E"]) : 0.00f;
|
||||||
|
float upload = tagValues.ContainsKey("853F") ? BitConverter.ToSingle(tagValues["853F"]) : 0.00f;
|
||||||
|
Console.WriteLine(" DL: \t{0} b/s ({1:0.000} {2}B/s)", download, download / (download < 8e6f ? (8.0f * 1024.0f) : (8.0f * 1024.0f * 1024.0f)), download < 8e6 ? "k" : "M");
|
||||||
|
Console.WriteLine(" UL: \t{0} b/s ({1:0.000} {2}B/s)", upload, upload / (upload < 8e6f ? (8.0f * 1024.0f) : (8.0f *1024.0f * 1024.0f)), upload < 8e6 ? "k" : "M");
|
||||||
|
Console.WriteLine(" Ping: \t{0} ms", tagValues.ContainsKey("8D3F") ? BitConverter.ToSingle(tagValues["8D3F"]) : 0.00);
|
||||||
|
Console.WriteLine(" Boresite Azimuth: \t{0}°", tagValues.ContainsKey("9D3F") ? BitConverter.ToSingle(tagValues["9D3F"]) : 0.00);
|
||||||
|
Console.WriteLine("Boresite Elevation: \t{0}°", tagValues.ContainsKey("A53F") ? BitConverter.ToSingle(tagValues["A53F"]) : 0.00);
|
||||||
|
}
|
||||||
|
catch { }
|
||||||
|
}
|
||||||
|
|
||||||
|
public static int LastIndexOf(byte[] src, byte[] searchBytes)
|
||||||
|
{
|
||||||
|
if (src.Length <= searchBytes.Length) return -1;
|
||||||
|
int pos = src.Length - searchBytes.Length;
|
||||||
|
while (pos > -1 && !exactMatch(src, searchBytes, pos))
|
||||||
|
{
|
||||||
|
pos--;
|
||||||
|
}
|
||||||
|
return pos;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool exactMatch(byte[] src, byte[] search, int pos)
|
||||||
|
{
|
||||||
|
for (int i = 0; i < search.Length; i++)
|
||||||
|
{
|
||||||
|
if (src[pos+i] != search[i])
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
10
StarlinkConnectionTest/StarlinkConnectionTest.csproj
Normal file
10
StarlinkConnectionTest/StarlinkConnectionTest.csproj
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
<Project Sdk="Microsoft.NET.Sdk">
|
||||||
|
|
||||||
|
<PropertyGroup>
|
||||||
|
<OutputType>Exe</OutputType>
|
||||||
|
<TargetFramework>net6.0</TargetFramework>
|
||||||
|
<ImplicitUsings>enable</ImplicitUsings>
|
||||||
|
<Nullable>enable</Nullable>
|
||||||
|
</PropertyGroup>
|
||||||
|
|
||||||
|
</Project>
|
Loading…
x
Reference in New Issue
Block a user