mirror of
https://github.com/9ParsonsB/Pulsar.git
synced 2025-04-05 17:39:39 -04:00
API & WebSocket now working
Can Read Status File & Broadcast contents via websocket
This commit is contained in:
parent
aa368471fe
commit
ac30d3cd2a
@ -1,336 +0,0 @@
|
|||||||
; Script generated by the Inno Setup Script Wizard.
|
|
||||||
; SEE THE DOCUMENTATION FOR DETAILS ON CREATING INNO SETUP SCRIPT FILES!
|
|
||||||
|
|
||||||
#define MyAppName "Elite Observatory"
|
|
||||||
#define MyAppPublisher "Jonathan Miller"
|
|
||||||
#define MyAppURL "https://github.com/xjph/ObservatoryCore"
|
|
||||||
#define MyAppExeName "ObservatoryCore.exe"
|
|
||||||
#define MyAppVersion GetVersionNumbersString('..\ObservatoryCore\bin\Release\net6.0\publish\framework-dependent\ObservatoryCore.exe')
|
|
||||||
|
|
||||||
[Setup]
|
|
||||||
; NOTE: The value of AppId uniquely identifies this application. Do not use the same AppId value in installers for other applications.
|
|
||||||
; (To generate a new GUID, click Tools | Generate GUID inside the IDE.)
|
|
||||||
AppId={{025F6049-430E-45D9-833E-30F0F5D998F5}
|
|
||||||
AppName={#MyAppName}
|
|
||||||
AppVersion={#MyAppVersion}
|
|
||||||
;AppVerName={#MyAppName} {#MyAppVersion}
|
|
||||||
AppPublisher={#MyAppPublisher}
|
|
||||||
AppPublisherURL={#MyAppURL}
|
|
||||||
AppSupportURL={#MyAppURL}
|
|
||||||
AppUpdatesURL={#MyAppURL}
|
|
||||||
DefaultDirName={autopf}\{#MyAppName}
|
|
||||||
DisableDirPage=false
|
|
||||||
DefaultGroupName={#MyAppName}
|
|
||||||
AllowNoIcons=yes
|
|
||||||
LicenseFile=C:\Users\Xjph\Repos\MIT.txt
|
|
||||||
; Uncomment the following line to run in non administrative install mode (install for current user only.)
|
|
||||||
;PrivilegesRequired=lowest
|
|
||||||
PrivilegesRequiredOverridesAllowed=dialog
|
|
||||||
OutputDir=.
|
|
||||||
OutputBaseFilename=ObservatorySetup
|
|
||||||
SetupIconFile=..\ObservatoryCore\Assets\EOCIcon-Presized.ico
|
|
||||||
Compression=lzma
|
|
||||||
SolidCompression=yes
|
|
||||||
WizardStyle=modern
|
|
||||||
ArchitecturesInstallIn64BitMode=x64
|
|
||||||
ChangesAssociations=yes
|
|
||||||
|
|
||||||
[Languages]
|
|
||||||
Name: "english"; MessagesFile: "compiler:Default.isl"
|
|
||||||
|
|
||||||
[Tasks]
|
|
||||||
Name: "desktopicon"; Description: "{cm:CreateDesktopIcon}"; GroupDescription: "{cm:AdditionalIcons}"; Flags: unchecked
|
|
||||||
|
|
||||||
[Types]
|
|
||||||
Name: "Full"; Description: "Full installation"
|
|
||||||
Name: "Custom"; Description: "Custom installation"; Flags: iscustom
|
|
||||||
|
|
||||||
[CustomMessages]
|
|
||||||
TelegramDescription=Telegram: Plugin for sending notifications via Telegram instant messages.%nProvided by Matt-G (mgraham-dev).
|
|
||||||
|
|
||||||
[Components]
|
|
||||||
Name: "Core"; Description: "Core Elite Observatory Application"; Flags: fixed; Types: Full Custom
|
|
||||||
Name: "Plugins"; Description: "Optional Observatory Plugins"; Types: Full
|
|
||||||
Name: "Plugins\Explorer"; Description: "Explorer: Plugin for finding interesting objects while exploring."; Types: Full
|
|
||||||
Name: "Plugins\Botanist"; Description: "Botanist: Plugin for tracking surface biological signals scanned while on foot."; Types: Full
|
|
||||||
Name: "Plugins\Herald"; Description: "Herald: Plugin for cloud-based high quality speech notifications via Microsoft Azure Cognitive Services."; Types: Full
|
|
||||||
Name: "Plugins\Telegram"; Description: "{cm:TelegramDescription}"; Types: Full
|
|
||||||
|
|
||||||
[Dirs]
|
|
||||||
Name: "{app}\plugins"; Permissions: users-modify
|
|
||||||
|
|
||||||
[Files]
|
|
||||||
Source: "..\ObservatoryCore\bin\Release\net6.0\publish\framework-dependent\{#MyAppExeName}"; DestDir: "{app}"; Flags: ignoreversion
|
|
||||||
Source: "..\ObservatoryCore\bin\Release\net6.0\publish\framework-dependent\*"; Excludes: "\plugins\*"; DestDir: "{app}"; Flags: ignoreversion recursesubdirs createallsubdirs
|
|
||||||
Source: "..\ObservatoryCore\bin\Release\net6.0\plugins\ObservatoryExplorer.dll"; DestDir: "{app}\plugins"; Components: Plugins\Explorer
|
|
||||||
Source: "..\ObservatoryCore\bin\Release\net6.0\plugins\deps\lua54.dll"; DestDir: "{app}\plugins\deps"; Components: Plugins\Explorer
|
|
||||||
Source: "..\ObservatoryCore\bin\Release\net6.0\plugins\deps\KeraLua.dll"; DestDir: "{app}\plugins\deps"; Components: Plugins\Explorer
|
|
||||||
Source: "..\ObservatoryCore\bin\Release\net6.0\plugins\deps\NLua.dll"; DestDir: "{app}\plugins\deps"; Components: Plugins\Explorer
|
|
||||||
Source: "..\ObservatoryCore\bin\Release\net6.0\plugins\ObservatoryHerald.dll"; DestDir: "{app}\plugins"; Components: Plugins\Herald
|
|
||||||
Source: "..\ObservatoryCore\bin\Release\net6.0\plugins\ObservatoryBotanist.dll"; DestDir: "{app}\plugins"; Components: Plugins\Botanist
|
|
||||||
Source: "..\ObservatoryCore\bin\Release\net6.0\plugins\ObservatoryTelegram.dll"; DestDir: "{app}\plugins"; Components: Plugins\Telegram
|
|
||||||
Source: ".\netcorecheck.exe"; Flags: dontcopy noencryption
|
|
||||||
Source: ".\netcorecheck_x64.exe"; Flags: dontcopy noencryption
|
|
||||||
|
|
||||||
[Icons]
|
|
||||||
Name: "{group}\{#MyAppName}"; Filename: "{app}\{#MyAppExeName}"
|
|
||||||
Name: "{autodesktop}\{#MyAppName}"; Filename: "{app}\{#MyAppExeName}"; Tasks: desktopicon
|
|
||||||
|
|
||||||
[Run]
|
|
||||||
Filename: "{app}\{#MyAppExeName}"; Description: "{cm:LaunchProgram,{#StringChange(MyAppName, '&', '&&')}}"; Flags: nowait postinstall skipifsilent
|
|
||||||
|
|
||||||
[Registry]
|
|
||||||
Root: HKA; Subkey: "Software\Classes\.eop\OpenWithProgids"; ValueType: string; ValueName: "ObservatoryPlugin.eop"; ValueData: ""; Flags: uninsdeletevalue
|
|
||||||
Root: HKA; Subkey: "Software\Classes\ObservatoryPlugin.eop"; ValueType: string; ValueName: ""; ValueData: "Elite Observatory Plugin"; Flags: uninsdeletekey
|
|
||||||
Root: HKA; Subkey: "Software\Classes\ObservatoryPlugin.eop\DefaultIcon"; ValueType: string; ValueName: ""; ValueData: "{app}\{#MyAppExeName},0"
|
|
||||||
Root: HKA; Subkey: "Software\Classes\ObservatoryPlugin.eop\shell\open\command"; ValueType: string; ValueName: ""; ValueData: """{app}\{#MyAppExeName}"" ""%1"""
|
|
||||||
Root: HKA; Subkey: "Software\Classes\Applications\{#MyAppExeName}\SupportedTypes"; ValueType: string; ValueName: ".eop"; ValueData: ""
|
|
||||||
|
|
||||||
[Code]
|
|
||||||
|
|
||||||
type
|
|
||||||
TDependency_Entry = record
|
|
||||||
Filename: String;
|
|
||||||
Parameters: String;
|
|
||||||
Title: String;
|
|
||||||
URL: String;
|
|
||||||
Checksum: String;
|
|
||||||
ForceSuccess: Boolean;
|
|
||||||
RestartAfter: Boolean;
|
|
||||||
end;
|
|
||||||
|
|
||||||
var
|
|
||||||
Dependency_Memo: String;
|
|
||||||
Dependency_List: array of TDependency_Entry;
|
|
||||||
Dependency_NeedRestart, Dependency_ForceX86: Boolean;
|
|
||||||
Dependency_DownloadPage: TDownloadWizardPage;
|
|
||||||
|
|
||||||
procedure InitializeWizard;
|
|
||||||
begin
|
|
||||||
Dependency_DownloadPage := CreateDownloadPage(SetupMessage(msgWizardPreparing), SetupMessage(msgPreparingDesc), nil);
|
|
||||||
end;
|
|
||||||
|
|
||||||
function Dependency_PrepareToInstall(var NeedsRestart: Boolean): String;
|
|
||||||
var
|
|
||||||
DependencyCount, DependencyIndex, ResultCode: Integer;
|
|
||||||
Retry: Boolean;
|
|
||||||
TempValue: String;
|
|
||||||
begin
|
|
||||||
DependencyCount := GetArrayLength(Dependency_List);
|
|
||||||
|
|
||||||
if DependencyCount > 0 then begin
|
|
||||||
Dependency_DownloadPage.Show;
|
|
||||||
|
|
||||||
for DependencyIndex := 0 to DependencyCount - 1 do begin
|
|
||||||
if Dependency_List[DependencyIndex].URL <> '' then begin
|
|
||||||
Dependency_DownloadPage.Clear;
|
|
||||||
Dependency_DownloadPage.Add(Dependency_List[DependencyIndex].URL, Dependency_List[DependencyIndex].Filename, Dependency_List[DependencyIndex].Checksum);
|
|
||||||
|
|
||||||
Retry := True;
|
|
||||||
while Retry do begin
|
|
||||||
Retry := False;
|
|
||||||
|
|
||||||
try
|
|
||||||
Dependency_DownloadPage.Download;
|
|
||||||
except
|
|
||||||
if Dependency_DownloadPage.AbortedByUser then begin
|
|
||||||
Result := Dependency_List[DependencyIndex].Title;
|
|
||||||
DependencyIndex := DependencyCount;
|
|
||||||
end else begin
|
|
||||||
case SuppressibleMsgBox(AddPeriod(GetExceptionMessage), mbError, MB_ABORTRETRYIGNORE, IDIGNORE) of
|
|
||||||
IDABORT: begin
|
|
||||||
Result := Dependency_List[DependencyIndex].Title;
|
|
||||||
DependencyIndex := DependencyCount;
|
|
||||||
end;
|
|
||||||
IDRETRY: begin
|
|
||||||
Retry := True;
|
|
||||||
end;
|
|
||||||
end;
|
|
||||||
end;
|
|
||||||
end;
|
|
||||||
end;
|
|
||||||
end;
|
|
||||||
end;
|
|
||||||
|
|
||||||
if Result = '' then begin
|
|
||||||
for DependencyIndex := 0 to DependencyCount - 1 do begin
|
|
||||||
Dependency_DownloadPage.SetText(Dependency_List[DependencyIndex].Title, '');
|
|
||||||
Dependency_DownloadPage.SetProgress(DependencyIndex + 1, DependencyCount + 1);
|
|
||||||
|
|
||||||
while True do begin
|
|
||||||
ResultCode := 0;
|
|
||||||
if ShellExec('', ExpandConstant('{tmp}{\}') + Dependency_List[DependencyIndex].Filename, Dependency_List[DependencyIndex].Parameters, '', SW_SHOWNORMAL, ewWaitUntilTerminated, ResultCode) then begin
|
|
||||||
if Dependency_List[DependencyIndex].RestartAfter then begin
|
|
||||||
if DependencyIndex = DependencyCount - 1 then begin
|
|
||||||
Dependency_NeedRestart := True;
|
|
||||||
end else begin
|
|
||||||
NeedsRestart := True;
|
|
||||||
Result := Dependency_List[DependencyIndex].Title;
|
|
||||||
end;
|
|
||||||
break;
|
|
||||||
end else if (ResultCode = 0) or Dependency_List[DependencyIndex].ForceSuccess then begin // ERROR_SUCCESS (0)
|
|
||||||
break;
|
|
||||||
end else if ResultCode = 1641 then begin // ERROR_SUCCESS_REBOOT_INITIATED (1641)
|
|
||||||
NeedsRestart := True;
|
|
||||||
Result := Dependency_List[DependencyIndex].Title;
|
|
||||||
break;
|
|
||||||
end else if ResultCode = 3010 then begin // ERROR_SUCCESS_REBOOT_REQUIRED (3010)
|
|
||||||
Dependency_NeedRestart := True;
|
|
||||||
break;
|
|
||||||
end;
|
|
||||||
end;
|
|
||||||
|
|
||||||
case SuppressibleMsgBox(FmtMessage(SetupMessage(msgErrorFunctionFailed), [Dependency_List[DependencyIndex].Title, IntToStr(ResultCode)]), mbError, MB_ABORTRETRYIGNORE, IDIGNORE) of
|
|
||||||
IDABORT: begin
|
|
||||||
Result := Dependency_List[DependencyIndex].Title;
|
|
||||||
break;
|
|
||||||
end;
|
|
||||||
IDIGNORE: begin
|
|
||||||
break;
|
|
||||||
end;
|
|
||||||
end;
|
|
||||||
end;
|
|
||||||
|
|
||||||
if Result <> '' then begin
|
|
||||||
break;
|
|
||||||
end;
|
|
||||||
end;
|
|
||||||
|
|
||||||
if NeedsRestart then begin
|
|
||||||
TempValue := '"' + ExpandConstant('{srcexe}') + '" /restart=1 /LANG="' + ExpandConstant('{language}') + '" /DIR="' + WizardDirValue + '" /GROUP="' + WizardGroupValue + '" /TYPE="' + WizardSetupType(False) + '" /COMPONENTS="' + WizardSelectedComponents(False) + '" /TASKS="' + WizardSelectedTasks(False) + '"';
|
|
||||||
if WizardNoIcons then begin
|
|
||||||
TempValue := TempValue + ' /NOICONS';
|
|
||||||
end;
|
|
||||||
RegWriteStringValue(HKA, 'SOFTWARE\Microsoft\Windows\CurrentVersion\RunOnce', '{#SetupSetting("AppName")}', TempValue);
|
|
||||||
end;
|
|
||||||
end;
|
|
||||||
|
|
||||||
Dependency_DownloadPage.Hide;
|
|
||||||
end;
|
|
||||||
end;
|
|
||||||
|
|
||||||
function PrepareToInstall(var NeedsRestart: Boolean): String;
|
|
||||||
begin
|
|
||||||
Result := Dependency_PrepareToInstall(NeedsRestart);
|
|
||||||
end;
|
|
||||||
|
|
||||||
function NeedRestart: Boolean;
|
|
||||||
begin
|
|
||||||
Result := Dependency_NeedRestart;
|
|
||||||
end;
|
|
||||||
|
|
||||||
function Dependency_UpdateReadyMemo(const Space, NewLine, MemoUserInfoInfo, MemoDirInfo, MemoTypeInfo, MemoComponentsInfo, MemoGroupInfo, MemoTasksInfo: String): String;
|
|
||||||
begin
|
|
||||||
Result := '';
|
|
||||||
if MemoUserInfoInfo <> '' then begin
|
|
||||||
Result := Result + MemoUserInfoInfo + Newline + NewLine;
|
|
||||||
end;
|
|
||||||
if MemoDirInfo <> '' then begin
|
|
||||||
Result := Result + MemoDirInfo + Newline + NewLine;
|
|
||||||
end;
|
|
||||||
if MemoTypeInfo <> '' then begin
|
|
||||||
Result := Result + MemoTypeInfo + Newline + NewLine;
|
|
||||||
end;
|
|
||||||
if MemoComponentsInfo <> '' then begin
|
|
||||||
Result := Result + MemoComponentsInfo + Newline + NewLine;
|
|
||||||
end;
|
|
||||||
if MemoGroupInfo <> '' then begin
|
|
||||||
Result := Result + MemoGroupInfo + Newline + NewLine;
|
|
||||||
end;
|
|
||||||
if MemoTasksInfo <> '' then begin
|
|
||||||
Result := Result + MemoTasksInfo;
|
|
||||||
end;
|
|
||||||
|
|
||||||
if Dependency_Memo <> '' then begin
|
|
||||||
if MemoTasksInfo = '' then begin
|
|
||||||
Result := Result + SetupMessage(msgReadyMemoTasks);
|
|
||||||
end;
|
|
||||||
Result := Result + FmtMessage(Dependency_Memo, [Space]);
|
|
||||||
end;
|
|
||||||
end;
|
|
||||||
|
|
||||||
function UpdateReadyMemo(const Space, NewLine, MemoUserInfoInfo, MemoDirInfo, MemoTypeInfo, MemoComponentsInfo, MemoGroupInfo, MemoTasksInfo: String): String;
|
|
||||||
begin
|
|
||||||
Result := Dependency_UpdateReadyMemo(Space, NewLine, MemoUserInfoInfo, MemoDirInfo, MemoTypeInfo, MemoComponentsInfo, MemoGroupInfo, MemoTasksInfo);
|
|
||||||
end;
|
|
||||||
|
|
||||||
function Dependency_IsX64: Boolean;
|
|
||||||
begin
|
|
||||||
Result := not Dependency_ForceX86 and Is64BitInstallMode;
|
|
||||||
end;
|
|
||||||
|
|
||||||
function Dependency_String(const x86, x64: String): String;
|
|
||||||
begin
|
|
||||||
if Dependency_IsX64 then begin
|
|
||||||
Result := x64;
|
|
||||||
end else begin
|
|
||||||
Result := x86;
|
|
||||||
end;
|
|
||||||
end;
|
|
||||||
|
|
||||||
function Dependency_ArchSuffix: String;
|
|
||||||
begin
|
|
||||||
Result := Dependency_String('', '_x64');
|
|
||||||
end;
|
|
||||||
|
|
||||||
function Dependency_ArchTitle: String;
|
|
||||||
begin
|
|
||||||
Result := Dependency_String(' (x86)', ' (x64)');
|
|
||||||
end;
|
|
||||||
|
|
||||||
function Dependency_IsNetCoreInstalled(const Version: String): Boolean;
|
|
||||||
var
|
|
||||||
ResultCode: Integer;
|
|
||||||
begin
|
|
||||||
// source code: https://github.com/dotnet/deployment-tools/tree/master/src/clickonce/native/projects/NetCoreCheck
|
|
||||||
if not FileExists(ExpandConstant('{tmp}{\}') + 'netcorecheck' + Dependency_ArchSuffix + '.exe') then begin
|
|
||||||
ExtractTemporaryFile('netcorecheck' + Dependency_ArchSuffix + '.exe');
|
|
||||||
end;
|
|
||||||
Result := ShellExec('', ExpandConstant('{tmp}{\}') + 'netcorecheck' + Dependency_ArchSuffix + '.exe', Version, '', SW_HIDE, ewWaitUntilTerminated, ResultCode) and (ResultCode = 0);
|
|
||||||
end;
|
|
||||||
|
|
||||||
procedure Dependency_Add(const Filename, Parameters, Title, URL, Checksum: String; const ForceSuccess, RestartAfter: Boolean);
|
|
||||||
var
|
|
||||||
Dependency: TDependency_Entry;
|
|
||||||
DependencyCount: Integer;
|
|
||||||
begin
|
|
||||||
Dependency_Memo := Dependency_Memo + #13#10 + '%1' + Title;
|
|
||||||
|
|
||||||
Dependency.Filename := Filename;
|
|
||||||
Dependency.Parameters := Parameters;
|
|
||||||
Dependency.Title := Title;
|
|
||||||
|
|
||||||
if FileExists(ExpandConstant('{tmp}{\}') + Filename) then begin
|
|
||||||
Dependency.URL := '';
|
|
||||||
end else begin
|
|
||||||
Dependency.URL := URL;
|
|
||||||
end;
|
|
||||||
|
|
||||||
Dependency.Checksum := Checksum;
|
|
||||||
Dependency.ForceSuccess := ForceSuccess;
|
|
||||||
Dependency.RestartAfter := RestartAfter;
|
|
||||||
|
|
||||||
DependencyCount := GetArrayLength(Dependency_List);
|
|
||||||
SetArrayLength(Dependency_List, DependencyCount + 1);
|
|
||||||
Dependency_List[DependencyCount] := Dependency;
|
|
||||||
end;
|
|
||||||
|
|
||||||
procedure Dependency_AddDotNet60Desktop;
|
|
||||||
begin
|
|
||||||
// https://dotnet.microsoft.com/download/dotnet/5.0
|
|
||||||
if not Dependency_IsNetCoreInstalled('Microsoft.WindowsDesktop.App 6.0.11') then begin
|
|
||||||
Dependency_Add('dotnet50desktop' + Dependency_ArchSuffix + '.exe',
|
|
||||||
'/lcid ' + IntToStr(GetUILanguage) + ' /passive /norestart',
|
|
||||||
'.NET Desktop Runtime 6.0.11' + Dependency_ArchTitle,
|
|
||||||
Dependency_String('https://download.visualstudio.microsoft.com/download/pr/2a392287-fd51-4ee8-9c15-a672ab9bc55d/03d4784b3a543a0fb9ce5677ed13a9a3/windowsdesktop-runtime-6.0.11-win-x86.exe', 'https://download.visualstudio.microsoft.com/download/pr/0192a249-3ec8-4374-a827-e186dd58d55d/cec046575f3eb2247a10ba3d50f5cf6c/windowsdesktop-runtime-6.0.11-win-x64.exe'),
|
|
||||||
'', False, False);
|
|
||||||
end;
|
|
||||||
end;
|
|
||||||
|
|
||||||
function InitializeSetup: Boolean;
|
|
||||||
begin
|
|
||||||
// add the dependencies you need
|
|
||||||
Dependency_AddDotNet60Desktop;
|
|
||||||
// ...
|
|
||||||
Result := true;
|
|
||||||
end;
|
|
Binary file not shown.
Binary file not shown.
2
LICENSE
2
LICENSE
@ -1,6 +1,6 @@
|
|||||||
MIT License
|
MIT License
|
||||||
|
|
||||||
Copyright (c) 2021 Jonathan Miller
|
Copyright (c) 2021-2024 Elite Observatory Contributors & Others
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
@ -7,13 +7,13 @@ class PipConverter : JsonConverter<(int Sys, int Eng, int Wep)>
|
|||||||
{
|
{
|
||||||
public override (int Sys, int Eng, int Wep) Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options)
|
public override (int Sys, int Eng, int Wep) Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options)
|
||||||
{
|
{
|
||||||
var values = (int[])JsonSerializer.Deserialize(ref reader, typeof(int[]));
|
var values = JsonSerializer.Deserialize<int[]>(ref reader);
|
||||||
|
|
||||||
return (Sys: values[0], Eng: values[1], Wep: values[2]);
|
return (Sys: values[0], Eng: values[1], Wep: values[2]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public override void Write(Utf8JsonWriter writer, (int Sys, int Eng, int Wep) value, JsonSerializerOptions options)
|
public override void Write(Utf8JsonWriter writer, (int Sys, int Eng, int Wep) value, JsonSerializerOptions options)
|
||||||
{
|
{
|
||||||
throw new NotImplementedException();
|
JsonSerializer.Serialize(writer, new[] { value.Sys, value.Eng, value.Wep });
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -18,84 +18,84 @@ public class Status : JournalBase
|
|||||||
/// Additional set of flags representing current player state.
|
/// Additional set of flags representing current player state.
|
||||||
/// Added in later versions of Elite Dangerous.
|
/// Added in later versions of Elite Dangerous.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public StatusFlags2 Flags2 { get; init; }
|
public StatusFlags2? Flags2 { get; init; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Current allocation of power distribution (pips) between SYS, ENG, and WEP, in "half pip" increments.
|
/// Current allocation of power distribution (pips) between SYS, ENG, and WEP, in "half pip" increments.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
[JsonConverter(typeof(PipConverter))]
|
[JsonConverter(typeof(PipConverter))]
|
||||||
public (int Sys, int Eng, int Wep) Pips { get; init; }
|
public (int Sys, int Eng, int Wep)? Pips { get; init; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Currently selected fire group.
|
/// Currently selected fire group.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public int Firegroup { get; init; }
|
public int? Firegroup { get; init; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// UI component currently focused by the player.
|
/// UI component currently focused by the player.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public FocusStatus GuiFocus { get; init; }
|
public FocusStatus? GuiFocus { get; init; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Fuel remaining in the current ship.
|
/// Fuel remaining in the current ship.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public FuelType Fuel { get; init; }
|
public FuelType? Fuel { get; init; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Amount of cargo currently carried.
|
/// Amount of cargo currently carried.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public float Cargo { get; init; }
|
public float? Cargo { get; init; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Legal status in the current jurisdiction.
|
/// Legal status in the current jurisdiction.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
[JsonConverter(typeof(JsonStringEnumConverter))]
|
[JsonConverter(typeof(JsonStringEnumConverter))]
|
||||||
public LegalStatus LegalState { get; init; }
|
public LegalStatus? LegalState { get; init; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// <para>Current altitude.</para>
|
/// <para>Current altitude.</para>
|
||||||
/// <para>Check if RadialAltitude is set in StatusFlags to determine if altitude is based on planetary radius (set) or raycast to ground (unset).</para>
|
/// <para>Check if RadialAltitude is set in StatusFlags to determine if altitude is based on planetary radius (set) or raycast to ground (unset).</para>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public int Altitude { get; init; }
|
public int? Altitude { get; init; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Latitude of current surface location.
|
/// Latitude of current surface location.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public double Latitude { get; init; }
|
public double? Latitude { get; init; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Longitude of current surface location.
|
/// Longitude of current surface location.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public double Longitude { get; init; }
|
public double? Longitude { get; init; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Current heading for surface direction.
|
/// Current heading for surface direction.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public int Heading { get; init; }
|
public int? Heading { get; init; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Body name of current location.
|
/// Body name of current location.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public string BodyName { get; init; }
|
public string? BodyName { get; init; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Radius of current planet.
|
/// Radius of current planet.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public double PlanetRadius { get; init; }
|
public double? PlanetRadius { get; init; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Oxygen remaining on foot, range from 0.0 - 1.0.
|
/// Oxygen remaining on foot, range from 0.0 - 1.0.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public float Oxygen { get; init; }
|
public float? Oxygen { get; init; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Health remaining on foot, range from 0.0 - 1.0.
|
/// Health remaining on foot, range from 0.0 - 1.0.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public float Health { get; init; }
|
public float? Health { get; init; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Current environmental temperature in K while on foot.
|
/// Current environmental temperature in K while on foot.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public float Temperature { get; init; }
|
public float? Temperature { get; init; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Name of currently selected personal weapon.
|
/// Name of currently selected personal weapon.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public string SelectedWeapon { get; init; }
|
public string? SelectedWeapon { get; init; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Current strength of gravity while on foot, in g.
|
/// Current strength of gravity while on foot, in g.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public float Gravity { get; init; }
|
public float? Gravity { get; init; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Current credit balance of player.
|
/// Current credit balance of player.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public long Balance { get; init; }
|
public long? Balance { get; init; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Currently set destination.
|
/// Currently set destination.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public Destination Destination { get; init; }
|
public Destination? Destination { get; init; }
|
||||||
}
|
}
|
@ -4,7 +4,7 @@ using Observatory.Framework.Files;
|
|||||||
using Observatory.Framework.Files.Journal;
|
using Observatory.Framework.Files.Journal;
|
||||||
using Microsoft.AspNetCore.SignalR;
|
using Microsoft.AspNetCore.SignalR;
|
||||||
|
|
||||||
public class EventsHub : Hub<IEventHub>
|
public class EventsHub : Hub<IEventsHub>
|
||||||
{
|
{
|
||||||
public async Task StatusUpdated(Observatory.Framework.Files.Status status) => await Clients.All.StatusUpdated(status);
|
public async Task StatusUpdated(Observatory.Framework.Files.Status status) => await Clients.All.StatusUpdated(status);
|
||||||
|
|
||||||
@ -27,7 +27,7 @@ public class EventsHub : Hub<IEventHub>
|
|||||||
public async Task BackpackUpdated(BackpackFile backpack) => await Clients.All.BackpackUpdated(backpack);
|
public async Task BackpackUpdated(BackpackFile backpack) => await Clients.All.BackpackUpdated(backpack);
|
||||||
}
|
}
|
||||||
|
|
||||||
public interface IEventHub
|
public interface IEventsHub
|
||||||
{
|
{
|
||||||
Task StatusUpdated(Observatory.Framework.Files.Status status);
|
Task StatusUpdated(Observatory.Framework.Files.Status status);
|
||||||
|
|
||||||
|
@ -1,12 +1,32 @@
|
|||||||
|
using Microsoft.AspNetCore.SignalR;
|
||||||
|
|
||||||
namespace Pulsar.Features.Status;
|
namespace Pulsar.Features.Status;
|
||||||
|
|
||||||
[ApiController]
|
[ApiController]
|
||||||
[Route("api/status")]
|
[Route("api/status")]
|
||||||
public class StatusController : Controller
|
public class StatusController(IOptions<PulsarConfiguration> pulsarOptions, IHubContext<EventsHub, IEventsHub> hub) : ControllerBase
|
||||||
{
|
{
|
||||||
[HttpGet]
|
[HttpGet]
|
||||||
public IActionResult Get()
|
public async Task<IActionResult> Get()
|
||||||
{
|
{
|
||||||
return Ok();
|
// TODO: put in service
|
||||||
|
var journalDir = pulsarOptions.Value.JournalDirectory;
|
||||||
|
var dir = new DirectoryInfo(journalDir);
|
||||||
|
|
||||||
|
if (!dir.Exists)
|
||||||
|
return Problem("Journal directory does not exist.");
|
||||||
|
|
||||||
|
var files = dir.GetFiles();
|
||||||
|
|
||||||
|
var statusFile = files.FirstOrDefault(f =>
|
||||||
|
string.Equals(f.Name, "status.json", StringComparison.InvariantCultureIgnoreCase));
|
||||||
|
|
||||||
|
if (statusFile == null)
|
||||||
|
return Problem("Status file not found.");
|
||||||
|
|
||||||
|
await using var file = System.IO.File.Open(statusFile.FullName, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);
|
||||||
|
var status = await JsonSerializer.DeserializeAsync<Observatory.Framework.Files.Status>(file);
|
||||||
|
await hub.Clients.All.StatusUpdated(status);
|
||||||
|
return Ok(status);
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -5,3 +5,5 @@ global using System.Text.Json;
|
|||||||
global using System.Text.Json.Nodes;
|
global using System.Text.Json.Nodes;
|
||||||
global using System.Text.Json.Serialization;
|
global using System.Text.Json.Serialization;
|
||||||
global using Microsoft.AspNetCore.Mvc;
|
global using Microsoft.AspNetCore.Mvc;
|
||||||
|
global using Microsoft.Extensions.Options;
|
||||||
|
|
||||||
|
@ -1,18 +1,34 @@
|
|||||||
using Lamar.Microsoft.DependencyInjection;
|
using Lamar.Microsoft.DependencyInjection;
|
||||||
|
using Microsoft.AspNetCore.Cors.Infrastructure;
|
||||||
|
using Pulsar.Features;
|
||||||
|
|
||||||
var builder = WebApplication.CreateBuilder(args);
|
var builder = WebApplication.CreateBuilder(args);
|
||||||
|
|
||||||
builder.Services.AddLamar();
|
builder.Services.AddLamar();
|
||||||
builder.Services.AddControllers();
|
builder.Services.AddControllersWithViews();
|
||||||
builder.Services.AddSignalR();
|
builder.Services.AddCors(options =>
|
||||||
|
{
|
||||||
|
options.AddDefaultPolicy(new CorsPolicy()
|
||||||
|
{ Origins = { "http://localhost:5000" }, Headers = { "*" }, Methods = { "*" } });
|
||||||
|
});
|
||||||
|
builder.Services.AddSignalR().AddJsonProtocol(options =>
|
||||||
|
options.PayloadSerializerOptions.DefaultIgnoreCondition = JsonIgnoreCondition.WhenWritingNull);
|
||||||
builder.Services.AddDbContext<PulsarContext>();
|
builder.Services.AddDbContext<PulsarContext>();
|
||||||
builder.Services.Configure<PulsarConfiguration>(builder.Configuration.GetSection(nameof(Pulsar)));
|
builder.Services.Configure<PulsarConfiguration>(builder.Configuration.GetSection(nameof(Pulsar)));
|
||||||
|
builder.Services.Configure<JsonOptions>(options =>
|
||||||
|
options.JsonSerializerOptions.DefaultIgnoreCondition = JsonIgnoreCondition.WhenWritingNull);
|
||||||
|
builder.Services.AddReverseProxy().LoadFromConfig(builder.Configuration.GetSection("ReverseProxy"));
|
||||||
|
builder.Services.AddSpaYarp();
|
||||||
|
|
||||||
var app = builder.Build();
|
var app = builder.Build();
|
||||||
|
|
||||||
await app.RunAsync();
|
app.UseRouting();
|
||||||
|
app.MapReverseProxy();
|
||||||
|
app.MapControllers();
|
||||||
|
app.MapDefaultControllerRoute();
|
||||||
|
app.UseWebSockets();
|
||||||
|
app.MapHub<EventsHub>("api/events");
|
||||||
|
app.UseSpaYarp();
|
||||||
|
app.MapFallbackToFile("index.html");
|
||||||
|
|
||||||
public class PulsarConfiguration
|
await app.RunAsync();
|
||||||
{
|
|
||||||
public string JournalDirectory { get; set; }
|
|
||||||
}
|
|
@ -7,6 +7,8 @@
|
|||||||
<ImplicitUsings>enable</ImplicitUsings>
|
<ImplicitUsings>enable</ImplicitUsings>
|
||||||
<RootNamespace>Pulsar</RootNamespace>
|
<RootNamespace>Pulsar</RootNamespace>
|
||||||
<LangVersion>latest</LangVersion>
|
<LangVersion>latest</LangVersion>
|
||||||
|
<SpaRoot>WebApp/</SpaRoot>
|
||||||
|
<SpaClientUrl>http://localhost:5173</SpaClientUrl>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
@ -14,11 +16,13 @@
|
|||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
<PackageReference Include="AspNetCore.SpaYarp" Version="2.0.1" />
|
||||||
<PackageReference Include="Lamar" Version="13.0.3" />
|
<PackageReference Include="Lamar" Version="13.0.3" />
|
||||||
<PackageReference Include="Lamar.Microsoft.DependencyInjection" Version="13.0.3" />
|
<PackageReference Include="Lamar.Microsoft.DependencyInjection" Version="13.0.3" />
|
||||||
<PackageReference Include="Microsoft.EntityFrameworkCore" Version="8.0.4" />
|
<PackageReference Include="Microsoft.EntityFrameworkCore" Version="8.0.4" />
|
||||||
<PackageReference Include="Microsoft.EntityFrameworkCore.Sqlite" Version="8.0.4" />
|
<PackageReference Include="Microsoft.EntityFrameworkCore.Sqlite" Version="8.0.4" />
|
||||||
<PackageReference Include="Scrutor" Version="4.2.2" />
|
<PackageReference Include="Scrutor" Version="4.2.2" />
|
||||||
|
<PackageReference Include="Yarp.ReverseProxy" Version="2.1.0" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
</Project>
|
</Project>
|
6
Pulsar/PulsarConfiguration.cs
Normal file
6
Pulsar/PulsarConfiguration.cs
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
namespace Pulsar;
|
||||||
|
|
||||||
|
public class PulsarConfiguration
|
||||||
|
{
|
||||||
|
public string JournalDirectory { get; set; }
|
||||||
|
}
|
170
Pulsar/WebApp/package-lock.json
generated
170
Pulsar/WebApp/package-lock.json
generated
@ -9,6 +9,7 @@
|
|||||||
"version": "0.0.1",
|
"version": "0.0.1",
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@biomejs/biome": "1.6.4",
|
"@biomejs/biome": "1.6.4",
|
||||||
|
"@microsoft/signalr": "^8.0.0",
|
||||||
"@playwright/test": "^1.28.1",
|
"@playwright/test": "^1.28.1",
|
||||||
"@sveltejs/adapter-static": "^3.0.1",
|
"@sveltejs/adapter-static": "^3.0.1",
|
||||||
"@sveltejs/kit": "^2.0.0",
|
"@sveltejs/kit": "^2.0.0",
|
||||||
@ -729,6 +730,19 @@
|
|||||||
"@jridgewell/sourcemap-codec": "^1.4.14"
|
"@jridgewell/sourcemap-codec": "^1.4.14"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/@microsoft/signalr": {
|
||||||
|
"version": "8.0.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/@microsoft/signalr/-/signalr-8.0.0.tgz",
|
||||||
|
"integrity": "sha512-K/wS/VmzRWePCGqGh8MU8OWbS1Zvu7DG7LSJS62fBB8rJUXwwj4axQtqrAAwKGUZHQF6CuteuQR9xMsVpM2JNA==",
|
||||||
|
"dev": true,
|
||||||
|
"dependencies": {
|
||||||
|
"abort-controller": "^3.0.0",
|
||||||
|
"eventsource": "^2.0.2",
|
||||||
|
"fetch-cookie": "^2.0.3",
|
||||||
|
"node-fetch": "^2.6.7",
|
||||||
|
"ws": "^7.4.5"
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/@nodelib/fs.scandir": {
|
"node_modules/@nodelib/fs.scandir": {
|
||||||
"version": "2.1.5",
|
"version": "2.1.5",
|
||||||
"resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz",
|
"resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz",
|
||||||
@ -1333,6 +1347,18 @@
|
|||||||
"dev": true,
|
"dev": true,
|
||||||
"peer": true
|
"peer": true
|
||||||
},
|
},
|
||||||
|
"node_modules/abort-controller": {
|
||||||
|
"version": "3.0.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/abort-controller/-/abort-controller-3.0.0.tgz",
|
||||||
|
"integrity": "sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==",
|
||||||
|
"dev": true,
|
||||||
|
"dependencies": {
|
||||||
|
"event-target-shim": "^5.0.0"
|
||||||
|
},
|
||||||
|
"engines": {
|
||||||
|
"node": ">=6.5"
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/acorn": {
|
"node_modules/acorn": {
|
||||||
"version": "8.11.3",
|
"version": "8.11.3",
|
||||||
"resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz",
|
"resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz",
|
||||||
@ -1991,6 +2017,24 @@
|
|||||||
"node": ">=0.10.0"
|
"node": ">=0.10.0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/event-target-shim": {
|
||||||
|
"version": "5.0.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/event-target-shim/-/event-target-shim-5.0.1.tgz",
|
||||||
|
"integrity": "sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ==",
|
||||||
|
"dev": true,
|
||||||
|
"engines": {
|
||||||
|
"node": ">=6"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/eventsource": {
|
||||||
|
"version": "2.0.2",
|
||||||
|
"resolved": "https://registry.npmjs.org/eventsource/-/eventsource-2.0.2.tgz",
|
||||||
|
"integrity": "sha512-IzUmBGPR3+oUG9dUeXynyNmf91/3zUSJg1lCktzKw47OXuhco54U3r9B7O4XX+Rb1Itm9OZ2b0RkTs10bICOxA==",
|
||||||
|
"dev": true,
|
||||||
|
"engines": {
|
||||||
|
"node": ">=12.0.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/fast-deep-equal": {
|
"node_modules/fast-deep-equal": {
|
||||||
"version": "3.1.3",
|
"version": "3.1.3",
|
||||||
"resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
|
"resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
|
||||||
@ -2049,6 +2093,16 @@
|
|||||||
"reusify": "^1.0.4"
|
"reusify": "^1.0.4"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/fetch-cookie": {
|
||||||
|
"version": "2.2.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/fetch-cookie/-/fetch-cookie-2.2.0.tgz",
|
||||||
|
"integrity": "sha512-h9AgfjURuCgA2+2ISl8GbavpUdR+WGAM2McW/ovn4tVccegp8ZqCKWSBR8uRdM8dDNlx5WdKRWxBYUwteLDCNQ==",
|
||||||
|
"dev": true,
|
||||||
|
"dependencies": {
|
||||||
|
"set-cookie-parser": "^2.4.8",
|
||||||
|
"tough-cookie": "^4.0.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/file-entry-cache": {
|
"node_modules/file-entry-cache": {
|
||||||
"version": "6.0.1",
|
"version": "6.0.1",
|
||||||
"resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz",
|
"resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz",
|
||||||
@ -2614,6 +2668,26 @@
|
|||||||
"integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==",
|
"integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
|
"node_modules/node-fetch": {
|
||||||
|
"version": "2.7.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.7.0.tgz",
|
||||||
|
"integrity": "sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A==",
|
||||||
|
"dev": true,
|
||||||
|
"dependencies": {
|
||||||
|
"whatwg-url": "^5.0.0"
|
||||||
|
},
|
||||||
|
"engines": {
|
||||||
|
"node": "4.x || >=6.0.0"
|
||||||
|
},
|
||||||
|
"peerDependencies": {
|
||||||
|
"encoding": "^0.1.0"
|
||||||
|
},
|
||||||
|
"peerDependenciesMeta": {
|
||||||
|
"encoding": {
|
||||||
|
"optional": true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/normalize-path": {
|
"node_modules/normalize-path": {
|
||||||
"version": "3.0.0",
|
"version": "3.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
|
||||||
@ -2902,16 +2976,27 @@
|
|||||||
"node": ">= 0.8.0"
|
"node": ">= 0.8.0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/psl": {
|
||||||
|
"version": "1.9.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/psl/-/psl-1.9.0.tgz",
|
||||||
|
"integrity": "sha512-E/ZsdU4HLs/68gYzgGTkMicWTLPdAftJLfJFlLUAAKZGkStNU72sZjT66SnMDVOfOWY/YAoiD7Jxa9iHvngcag==",
|
||||||
|
"dev": true
|
||||||
|
},
|
||||||
"node_modules/punycode": {
|
"node_modules/punycode": {
|
||||||
"version": "2.3.1",
|
"version": "2.3.1",
|
||||||
"resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz",
|
"resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz",
|
||||||
"integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==",
|
"integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"peer": true,
|
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=6"
|
"node": ">=6"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/querystringify": {
|
||||||
|
"version": "2.2.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.2.0.tgz",
|
||||||
|
"integrity": "sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ==",
|
||||||
|
"dev": true
|
||||||
|
},
|
||||||
"node_modules/queue-microtask": {
|
"node_modules/queue-microtask": {
|
||||||
"version": "1.2.3",
|
"version": "1.2.3",
|
||||||
"resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz",
|
"resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz",
|
||||||
@ -2944,6 +3029,12 @@
|
|||||||
"node": ">=8.10.0"
|
"node": ">=8.10.0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/requires-port": {
|
||||||
|
"version": "1.0.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz",
|
||||||
|
"integrity": "sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ==",
|
||||||
|
"dev": true
|
||||||
|
},
|
||||||
"node_modules/resolve-from": {
|
"node_modules/resolve-from": {
|
||||||
"version": "4.0.0",
|
"version": "4.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz",
|
||||||
@ -3405,6 +3496,27 @@
|
|||||||
"node": ">=6"
|
"node": ">=6"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/tough-cookie": {
|
||||||
|
"version": "4.1.3",
|
||||||
|
"resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-4.1.3.tgz",
|
||||||
|
"integrity": "sha512-aX/y5pVRkfRnfmuX+OdbSdXvPe6ieKX/G2s7e98f4poJHnqH3281gDPm/metm6E/WRamfx7WC4HUqkWHfQHprw==",
|
||||||
|
"dev": true,
|
||||||
|
"dependencies": {
|
||||||
|
"psl": "^1.1.33",
|
||||||
|
"punycode": "^2.1.1",
|
||||||
|
"universalify": "^0.2.0",
|
||||||
|
"url-parse": "^1.5.3"
|
||||||
|
},
|
||||||
|
"engines": {
|
||||||
|
"node": ">=6"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/tr46": {
|
||||||
|
"version": "0.0.3",
|
||||||
|
"resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz",
|
||||||
|
"integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==",
|
||||||
|
"dev": true
|
||||||
|
},
|
||||||
"node_modules/ts-api-utils": {
|
"node_modules/ts-api-utils": {
|
||||||
"version": "1.3.0",
|
"version": "1.3.0",
|
||||||
"resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.3.0.tgz",
|
"resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.3.0.tgz",
|
||||||
@ -3488,6 +3600,15 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/universalify": {
|
||||||
|
"version": "0.2.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/universalify/-/universalify-0.2.0.tgz",
|
||||||
|
"integrity": "sha512-CJ1QgKmNg3CwvAv/kOFmtnEN05f0D/cn9QntgNOQlQF9dgvVTHj3t+8JPdjqawCHk7V/KA+fbUqzZ9XWhcqPUg==",
|
||||||
|
"dev": true,
|
||||||
|
"engines": {
|
||||||
|
"node": ">= 4.0.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/uri-js": {
|
"node_modules/uri-js": {
|
||||||
"version": "4.4.1",
|
"version": "4.4.1",
|
||||||
"resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz",
|
"resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz",
|
||||||
@ -3498,6 +3619,16 @@
|
|||||||
"punycode": "^2.1.0"
|
"punycode": "^2.1.0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/url-parse": {
|
||||||
|
"version": "1.5.10",
|
||||||
|
"resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.5.10.tgz",
|
||||||
|
"integrity": "sha512-WypcfiRhfeUP9vvF0j6rw0J3hrWrw6iZv3+22h6iRMJ/8z1Tj6XfLP4DsUix5MhMPnXpiHDoKyoZ/bdCkwBCiQ==",
|
||||||
|
"dev": true,
|
||||||
|
"dependencies": {
|
||||||
|
"querystringify": "^2.1.1",
|
||||||
|
"requires-port": "^1.0.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/util-deprecate": {
|
"node_modules/util-deprecate": {
|
||||||
"version": "1.0.2",
|
"version": "1.0.2",
|
||||||
"resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
|
"resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
|
||||||
@ -3587,6 +3718,22 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/webidl-conversions": {
|
||||||
|
"version": "3.0.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz",
|
||||||
|
"integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==",
|
||||||
|
"dev": true
|
||||||
|
},
|
||||||
|
"node_modules/whatwg-url": {
|
||||||
|
"version": "5.0.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz",
|
||||||
|
"integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==",
|
||||||
|
"dev": true,
|
||||||
|
"dependencies": {
|
||||||
|
"tr46": "~0.0.3",
|
||||||
|
"webidl-conversions": "^3.0.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/which": {
|
"node_modules/which": {
|
||||||
"version": "2.0.2",
|
"version": "2.0.2",
|
||||||
"resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
|
"resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
|
||||||
@ -3609,6 +3756,27 @@
|
|||||||
"integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==",
|
"integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
|
"node_modules/ws": {
|
||||||
|
"version": "7.5.9",
|
||||||
|
"resolved": "https://registry.npmjs.org/ws/-/ws-7.5.9.tgz",
|
||||||
|
"integrity": "sha512-F+P9Jil7UiSKSkppIiD94dN07AwvFixvLIj1Og1Rl9GGMuNipJnV9JzjD6XuqmAeiswGvUmNLjr5cFuXwNS77Q==",
|
||||||
|
"dev": true,
|
||||||
|
"engines": {
|
||||||
|
"node": ">=8.3.0"
|
||||||
|
},
|
||||||
|
"peerDependencies": {
|
||||||
|
"bufferutil": "^4.0.1",
|
||||||
|
"utf-8-validate": "^5.0.2"
|
||||||
|
},
|
||||||
|
"peerDependenciesMeta": {
|
||||||
|
"bufferutil": {
|
||||||
|
"optional": true
|
||||||
|
},
|
||||||
|
"utf-8-validate": {
|
||||||
|
"optional": true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/yallist": {
|
"node_modules/yallist": {
|
||||||
"version": "4.0.0",
|
"version": "4.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
"@sveltejs/kit": "^2.0.0",
|
"@sveltejs/kit": "^2.0.0",
|
||||||
"@sveltejs/vite-plugin-svelte": "^3.0.0",
|
"@sveltejs/vite-plugin-svelte": "^3.0.0",
|
||||||
"@types/eslint": "^8.56.7",
|
"@types/eslint": "^8.56.7",
|
||||||
|
"@microsoft/signalr": "^8.0.0",
|
||||||
"eslint-plugin-svelte": "^2.36.0",
|
"eslint-plugin-svelte": "^2.36.0",
|
||||||
"globals": "^15.0.0",
|
"globals": "^15.0.0",
|
||||||
"sass": "^1.75.0",
|
"sass": "^1.75.0",
|
||||||
|
@ -1,13 +1,56 @@
|
|||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
let x = $state(1)
|
import * as signalR from "@microsoft/signalr"
|
||||||
|
import {onMount} from "svelte";
|
||||||
|
let x = $state(null);
|
||||||
|
let textarea = $state("");
|
||||||
|
|
||||||
const increment = () => {
|
const connection = new signalR.HubConnectionBuilder()
|
||||||
x = x + 1;
|
.withUrl("http://localhost:5000/api/events")
|
||||||
|
.configureLogging(signalR.LogLevel.Information)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
onMount(async () => {
|
||||||
|
|
||||||
|
connection.onclose(async () => {
|
||||||
|
console.log("Lost connection to Event Hub. Attempting to reconnect...");
|
||||||
|
await connection.start();
|
||||||
|
});
|
||||||
|
|
||||||
|
connection.on("StatusUpdated", (message) => {
|
||||||
|
console.log('we did it!');
|
||||||
|
console.log(message);
|
||||||
|
textarea += JSON.stringify(message) + "\n"
|
||||||
|
});
|
||||||
|
|
||||||
|
await connection.start();
|
||||||
|
})
|
||||||
|
|
||||||
|
const getStatus = async () => {
|
||||||
|
var response = await fetch("http://localhost:5000/api/status", {
|
||||||
|
method: "GET",
|
||||||
|
headers: {
|
||||||
|
"Content-Type": "application/json",
|
||||||
|
"Accept": "application/json"
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
if (response.ok)
|
||||||
|
{
|
||||||
|
const data = await response.text();
|
||||||
|
console.log(data);
|
||||||
|
x = data;
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log(response);
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<h1>Welcome to Pulsar</h1>
|
<h1>Welcome to Pulsar</h1>
|
||||||
|
|
||||||
<button on:click={increment} > Increment </button>
|
<button on:click={getStatus}> GetStatus </button>
|
||||||
|
|
||||||
<span> {x} </span>
|
<span> {x} </span>
|
||||||
|
|
||||||
|
<br/>
|
||||||
|
|
||||||
|
<textarea bind:value={textarea}></textarea>
|
||||||
|
29
Pulsar/appsettings.development.json
Normal file
29
Pulsar/appsettings.development.json
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
{
|
||||||
|
"Logging": {
|
||||||
|
"LogLevel": {
|
||||||
|
"Default": "Information",
|
||||||
|
"Microsoft": "Warning",
|
||||||
|
"Microsoft.Hosting.Lifetime": "Information",
|
||||||
|
"Microsoft.AspNetCore": "Debug"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"ReverseProxy": {
|
||||||
|
"Routes": {
|
||||||
|
"spaDevRoute": {
|
||||||
|
"ClusterId": "spaDevCluster",
|
||||||
|
"Match": {
|
||||||
|
"Path": "{**catch-all}"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"Clusters": {
|
||||||
|
"spaDev": {
|
||||||
|
"Destinations": {
|
||||||
|
"spaDevServer": {
|
||||||
|
"Address": "http://localhost:5173"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
23
README.md
23
README.md
@ -1,25 +1,34 @@
|
|||||||
# Elite Pulsar
|
# Elite Pulsar
|
||||||
A Service for monitoring Elite Dangerous Journals & Events & A Web UI viewing information
|
|
||||||
|
|
||||||
Forked from Elite Observatory Core.
|
A Work In Progress Application For Presenting Game Data In Realtime From Elite Dangerous Journals & Events.
|
||||||
|
|
||||||
|
A Cross Platform Fork of Elite Observatory Core.
|
||||||
|
|
||||||
## Planned Feature
|
## Planned Feature
|
||||||
|
|
||||||
- [ ] Read the Journal
|
- [ ] Read the Journal
|
||||||
|
- [x] Read Status File
|
||||||
- [ ] Show Journal information ( Current Ship, Station, etc. )
|
- [ ] Show Journal information ( Current Ship, Station, etc. )
|
||||||
|
- [ ] Realtime API
|
||||||
- [ ] Realtime Journal Updates
|
- [ ] Realtime Journal Updates
|
||||||
- [ ] System Exploration Value
|
- [ ] System Exploration Value
|
||||||
- [ ] System Exobiology Value
|
- [ ] System Exobiology Value
|
||||||
|
- [ ] Fuel/Jump Warning
|
||||||
|
- [ ] Commodities Targets/Alerts (Commodity Above/Below value at current station)
|
||||||
|
- [ ] Outfitting Targets (does this station have wanted parts for build)
|
||||||
- [ ] CAPI Integration
|
- [ ] CAPI Integration
|
||||||
- [ ] EDDN Submission
|
- [ ] EDDN Submission
|
||||||
|
- [ ] Must be easilty disableable for sneaky business
|
||||||
- [ ] IGAU Submission
|
- [ ] IGAU Submission
|
||||||
- [ ] Plugin System
|
- [ ] Plugin System
|
||||||
- [ ] Tray Icon
|
- [ ] Overlay
|
||||||
|
- [ ] Tay Icon
|
||||||
|
|
||||||
## How To Use
|
## How To Use
|
||||||
|
|
||||||
|
TODO: make easy
|
||||||
|
|
||||||
|
- Build the web app
|
||||||
## Building
|
- install the service (web app must be served from the backend)
|
||||||
|
- configure journal directory in appsettings.json
|
||||||
|
- load the application
|
||||||
|
Loading…
x
Reference in New Issue
Block a user