2023-05-18 08:45:44 +00:00
|
|
|
using System.Data.Common;
|
|
|
|
using System.IdentityModel.Tokens.Jwt;
|
2023-05-11 08:20:47 +00:00
|
|
|
using System.Web;
|
2023-05-04 15:22:58 +00:00
|
|
|
using HandlebarsDotNet;
|
2023-05-11 08:20:47 +00:00
|
|
|
using InnovEnergy.App.RemoteSupportConsole;
|
2023-05-04 15:22:58 +00:00
|
|
|
using InnovEnergy.App.VrmGrabber.Database;
|
2023-04-27 14:59:45 +00:00
|
|
|
using Microsoft.AspNetCore.Mvc;
|
2023-05-04 15:22:58 +00:00
|
|
|
using FILE=System.IO.File;
|
2023-05-18 08:45:44 +00:00
|
|
|
using VrmInstallation = InnovEnergy.Lib.Victron.VictronVRM.Installation;
|
2023-04-27 14:59:45 +00:00
|
|
|
|
2023-05-04 15:22:58 +00:00
|
|
|
namespace InnovEnergy.App.VrmGrabber;
|
2023-04-27 14:59:45 +00:00
|
|
|
|
2023-05-18 10:38:34 +00:00
|
|
|
public record Install(
|
|
|
|
String Name,
|
|
|
|
String Ip,
|
|
|
|
Int64 Vrm,
|
|
|
|
String Identifier,
|
|
|
|
String Serial,
|
|
|
|
String EscapedName,
|
|
|
|
String Online,
|
|
|
|
String LastSeen,
|
|
|
|
Int64 NumBatteries,
|
|
|
|
String BatteryVersion
|
|
|
|
);
|
|
|
|
|
2023-05-04 15:22:58 +00:00
|
|
|
[Controller]
|
2023-04-27 14:59:45 +00:00
|
|
|
public class Controller : ControllerBase
|
|
|
|
{
|
2023-05-04 15:22:58 +00:00
|
|
|
[HttpGet]
|
|
|
|
[Route("/")]
|
|
|
|
[Produces("text/html")]
|
|
|
|
public ActionResult Index()
|
2023-04-27 14:59:45 +00:00
|
|
|
{
|
2023-05-04 15:22:58 +00:00
|
|
|
String source = @"<head>
|
2023-05-18 08:45:44 +00:00
|
|
|
<style>
|
|
|
|
tbody {
|
|
|
|
background-color: #e4f0f5;
|
|
|
|
}
|
|
|
|
|
|
|
|
table {
|
|
|
|
border-collapse: collapse;
|
|
|
|
width: 100%;
|
|
|
|
border: 2px solid rgb(200, 200, 200);
|
|
|
|
letter-spacing: 1px;
|
|
|
|
font-family: sans-serif;
|
|
|
|
font-size: 0.8rem;
|
2023-05-18 10:38:34 +00:00
|
|
|
position: relative; top: 0; bottom: 0; left: 0; right: 0;
|
2023-05-18 08:45:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
td,
|
|
|
|
th {
|
|
|
|
border: 1px solid rgb(190, 190, 190);
|
|
|
|
padding: 5px 10px;
|
2023-05-18 10:38:34 +00:00
|
|
|
position: sticky;
|
|
|
|
top: 0px;
|
|
|
|
background: white;
|
2023-05-18 08:45:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
td {
|
|
|
|
text-align: left;
|
2023-05-18 10:38:34 +00:00
|
|
|
}
|
|
|
|
#managerTable {
|
|
|
|
overflow: hidden;
|
2023-05-18 08:45:44 +00:00
|
|
|
}</style></head>
|
2023-05-18 10:38:34 +00:00
|
|
|
|
|
|
|
<div id='managerTable'>
|
2023-05-18 08:45:44 +00:00
|
|
|
<table>
|
|
|
|
<tbody>
|
2023-05-18 10:38:34 +00:00
|
|
|
<tr>
|
|
|
|
<th>Name</th>
|
|
|
|
<th>Gui</th>
|
|
|
|
<th>VRM</th>
|
|
|
|
<th>Grafana</th>
|
|
|
|
<th>Identifier</th>
|
|
|
|
<th>Last Seen</th>
|
|
|
|
<th>Serial</th>
|
|
|
|
<th>#Batteries</th>
|
|
|
|
<th>Firmware-Version</th>
|
|
|
|
</tr>
|
2023-05-18 08:45:44 +00:00
|
|
|
{{#inst}}
|
|
|
|
{{> installations}}
|
|
|
|
{{/inst}}
|
|
|
|
</tbody>
|
2023-05-18 10:38:34 +00:00
|
|
|
</table>
|
|
|
|
<div id='managerTable'>";
|
2023-05-04 15:22:58 +00:00
|
|
|
|
|
|
|
String partialSource =
|
|
|
|
@"<tr><td>{{Name}}</td>
|
2023-05-11 11:26:13 +00:00
|
|
|
<td><a target='_blank' href=http://{{Ip}}>{{online}} {{Ip}}</a></td>
|
2023-05-04 15:22:58 +00:00
|
|
|
<td><a target='_blank' href=https://vrm.victronenergy.com/installation/{{Vrm}}/dashboard>VRM</a></td>
|
2023-05-11 11:26:13 +00:00
|
|
|
<td><a target='_blank' href='https://salidomo.innovenergy.ch/d/ENkNRQXmk/installation?refresh=5s&orgId=1&var-Installation={{EscapedName}}&kiosk=tv'>Grafana</a></td>
|
2023-05-04 15:22:58 +00:00
|
|
|
<td>{{Identifier}}</td>
|
2023-05-18 08:45:44 +00:00
|
|
|
<td>{{LastSeen}}</td>
|
2023-05-11 08:20:47 +00:00
|
|
|
<td>{{Serial}}</td>
|
2023-05-18 10:38:34 +00:00
|
|
|
<td>{{NumBatteries}}</td>
|
|
|
|
<td>{{BatteryVersion}}</td>
|
2023-05-11 11:26:13 +00:00
|
|
|
</tr>";
|
2023-05-04 15:22:58 +00:00
|
|
|
|
2023-05-18 08:45:44 +00:00
|
|
|
|
|
|
|
var instList = Db.Installations.ToList();
|
|
|
|
if (instList.Count == 0) return new ContentResult
|
|
|
|
{
|
|
|
|
ContentType = "text/html",
|
|
|
|
Content = "<p>Please wait page is still loading</p>"
|
|
|
|
};
|
|
|
|
|
2023-05-04 15:22:58 +00:00
|
|
|
Handlebars.RegisterTemplate("installations", partialSource);
|
|
|
|
var template = Handlebars.Compile(source);
|
2023-05-18 10:38:34 +00:00
|
|
|
var insts = instList.Select(i => new Install(
|
|
|
|
i.Name,
|
|
|
|
i.Ip,
|
|
|
|
i.Vrm,
|
|
|
|
i.Identifier,
|
|
|
|
i.Serial,
|
|
|
|
i.EscapedName,
|
|
|
|
i.Online,
|
|
|
|
DateTimeOffset.FromUnixTimeSeconds(Convert.ToInt64(i.LastSeen)).ToString(),
|
|
|
|
i.NumberOfBatteries,
|
|
|
|
i.BatteryFirmwareVersion));
|
|
|
|
|
2023-05-04 15:22:58 +00:00
|
|
|
var data = new
|
|
|
|
{
|
2023-05-18 10:38:34 +00:00
|
|
|
inst = insts
|
2023-05-04 15:22:58 +00:00
|
|
|
};
|
2023-05-04 11:59:47 +00:00
|
|
|
|
2023-05-04 15:22:58 +00:00
|
|
|
var result = template(data);
|
|
|
|
|
|
|
|
return new ContentResult
|
|
|
|
{
|
|
|
|
ContentType = "text/html",
|
|
|
|
Content = result
|
|
|
|
};
|
2023-05-04 11:59:47 +00:00
|
|
|
}
|
|
|
|
|
2023-05-04 15:22:58 +00:00
|
|
|
// [HttpGet(nameof(GetInstallation))]
|
|
|
|
// [UnconditionalSuppressMessage("Trimming", "IL2026:Members annotated with 'RequiresUnreferencedCodeAttribute' require dynamic access otherwise can break functionality when trimming application code", Justification = "<Pending>")]
|
|
|
|
// public Object GetInstallation(UInt64 serialNumber)
|
|
|
|
// {
|
|
|
|
// var instList = Db.InstallationsAndDetails.Values.ToList();
|
|
|
|
// foreach (var detailList in instList.Select((value, index) => new { Value = value, Index = index}))
|
|
|
|
// {
|
|
|
|
// if (detailList.Value.All(detail => detail.Json["idSite"]?.GetValue<UInt64>() != serialNumber)) continue;
|
|
|
|
// var retour = Db.InstallationsAndDetails.Keys.ToList()[detailList.Index].Json;
|
|
|
|
// retour["details"] = JsonSerializer.Deserialize<JsonArray>(JsonSerializer.Serialize(detailList.Value.Select(d => d.Json).ToArray()));
|
|
|
|
// return retour;
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// return new NotFoundResult();
|
|
|
|
// }
|
2023-04-27 14:59:45 +00:00
|
|
|
}
|
|
|
|
|