Files
Moonlight/Moonlight/Shared/Views/Admin/Nodes/Edit.razor
Marcel Baumgartner ca64184faf Revert "Merge pull request #106 from Moonlight-Panel/DiscordBot"
This reverts commit f71fcc0f5d, reversing
changes made to e0bea9b61c.
2023-04-29 23:37:03 +02:00

228 lines
11 KiB
Plaintext

@page "/admin/nodes/edit/{id:int}"
@using Moonlight.App.Repositories
@using Moonlight.App.Database.Entities
@using Moonlight.App.Services
@using Microsoft.EntityFrameworkCore
@using BlazorTable
@inject NodeRepository NodeRepository
@inject SmartTranslateService SmartTranslateService
@inject NavigationManager NavigationManager
<OnlyAdmin>
<LazyLoader Load="Load" @ref="LazyLoader">
@if (Node == null)
{
<div class="alert alert-warning">
<TL>No node with this id found</TL>
</div>
}
else
{
<div class="d-flex">
<div class="flex-column">
<div class="card rounded-3 w-md-550px">
<div class="card-body">
<div class="d-flex flex-center flex-column-fluid">
<div class="form w-100 fv-plugins-bootstrap5 fv-plugins-framework">
<div class="fv-row mb-8">
<label class="form-label">
<TL>Nodename</TL>
</label>
<input @bind="Node.Name" type="text" placeholder="@(SmartTranslateService.Translate("Nodename"))" class="form-control bg-transparent">
</div>
<div class="fv-row mb-8">
<label class="form-label">
<TL>FQDN</TL>
</label>
<input @bind="Node.Fqdn" type="text" placeholder="@(SmartTranslateService.Translate("FQDN"))" class="form-control bg-transparent">
</div>
<div class="fv-row mb-8">
<label class="form-label">
<TL>Token Id</TL>
</label>
<input @bind="Node.TokenId" type="text" placeholder="@(SmartTranslateService.Translate("Token Id"))" class="blur-unless-hover form-control bg-transparent">
</div>
<div class="fv-row mb-8">
<label class="form-label">
<TL>Token</TL>
</label>
<input @bind="Node.Token" type="text" placeholder="@(SmartTranslateService.Translate("Token"))" class="blur-unless-hover form-control bg-transparent">
</div>
<div class="fv-row mb-8">
<label class="form-label">
<TL>Http port</TL>
</label>
<input @bind="Node.HttpPort" type="number" class="form-control bg-transparent">
</div>
<div class="fv-row mb-8">
<label class="form-label">
<TL>Sftp port</TL>
</label>
<input @bind="Node.SftpPort" type="number" class="form-control bg-transparent">
</div>
<div class="fv-row mb-8">
<label class="form-label">
<TL>Moonlight daemon port</TL>
</label>
<input @bind="Node.MoonlightDaemonPort" type="number" class="form-control bg-transparent">
</div>
<div class="fv-row mb-8">
<div class="input-group">
<label class="col-lg-4 col-form-label fw-semibold fs-6">
<TL>SSL</TL>
</label>
<div class="col-lg-8 d-flex align-items-center">
<div class="form-check form-check-solid form-switch form-check-custom fv-row">
<input @bind="Node.Ssl" class="form-check-input w-45px h-30px" type="checkbox" id="ssl">
<label class="form-check-label" for="ssl"></label>
</div>
</div>
</div>
</div>
<div class="fv-row mb-9">
<WButton Text="@(SmartTranslateService.Translate("Save"))"
WorkingText="@(SmartTranslateService.Translate("Saving"))"
CssClasses="btn-success"
OnClick="Save">
</WButton>
<a href="/admin/nodes" class="btn btn-primary">
<TL>Back</TL>
</a>
</div>
</div>
</div>
</div>
</div>
</div>
<div class="flex-column w-100">
<div class="ms-5 card card-body">
<div class="form w-100">
<div class="mb-8 row g-3">
<div class="col-auto">
<input @bind="Port" type="number" class="col-auto form-control bg-transparent">
</div>
<div class="col-auto">
<WButton Text="@(SmartTranslateService.Translate("Add"))"
WorkingText="@(SmartTranslateService.Translate("Adding"))"
CssClasses="col-auto btn-success"
OnClick="CreateAllocation">
</WButton>
</div>
<div class="col-auto">
<label class="form-label">
<TL>Start</TL>
</label>
<input @bind="StartPort" type="number" class="col-auto form-control bg-transparent">
</div>
<div class="col-auto">
<label class="form-label">
<TL>End</TL>
</label>
<input @bind="EndPort" type="number" class="col-auto form-control bg-transparent">
</div>
<div class="col-auto">
<WButton Text="@(SmartTranslateService.Translate("Add"))"
WorkingText="@(SmartTranslateService.Translate("Adding"))"
CssClasses="col-auto btn-success"
OnClick="CreateAllocationRange">
</WButton>
</div>
</div>
</div>
<Table TableItem="NodeAllocation" Items="Node.Allocations" PageSize="25" TableHeadClass="border-bottom border-gray-200 fs-6 text-gray-600 fw-bold bg-light bg-opacity-75">
<Column TableItem="NodeAllocation" Title="@(SmartTranslateService.Translate("Id"))" Field="@(x => x.Id)" Sortable="true" Filterable="true" Width="10%"/>
<Column TableItem="NodeAllocation" Title="@(SmartTranslateService.Translate("Port"))" Field="@(x => x.Port)" Sortable="true" Filterable="true" Width="10%"/>
<Column TableItem="NodeAllocation" Title="@(SmartTranslateService.Translate("Manage"))" Field="@(x => x.Id)" Sortable="true" Filterable="true" Width="20%">
<Template>
<WButton Text="@(SmartTranslateService.Translate("Delete"))"
WorkingText="@(SmartTranslateService.Translate("Deleting"))"
CssClasses="btn-danger"
OnClick="() => DeleteAllocation(context)">
</WButton>
</Template>
</Column>
<Pager ShowPageNumber="true" ShowTotalCount="true"/>
</Table>
</div>
</div>
</div>
}
</LazyLoader>
</OnlyAdmin>
@code
{
[Parameter]
public int Id { get; set; }
private Node? Node;
private LazyLoader LazyLoader;
private int Port = 2000;
private int StartPort = 2000;
private int EndPort = 3000;
private Task Load(LazyLoader arg)
{
Node = NodeRepository
.Get()
.Include(x => x.Allocations)
.FirstOrDefault(x => x.Id == Id);
return Task.CompletedTask;
}
private Task Save()
{
NodeRepository.Update(Node!);
NavigationManager.NavigateTo("/admin/nodes");
return Task.CompletedTask;
}
private async Task DeleteAllocation(NodeAllocation nodeAllocation)
{
//TODO: Check if a server is using the allocation
Node!.Allocations.Remove(nodeAllocation);
NodeRepository.Update(Node);
await LazyLoader.Reload();
}
private async Task CreateAllocation()
{
var nodeAllocation = new NodeAllocation()
{
Port = Port
};
Node!.Allocations.Add(nodeAllocation);
NodeRepository.Update(Node);
Port = 2000;
await LazyLoader.Reload();
}
private async Task CreateAllocationRange()
{
for (int i = StartPort; i < EndPort; i++)
{
var nodeAllocation = new NodeAllocation()
{
Port = i
};
Node!.Allocations.Add(nodeAllocation);
}
NodeRepository.Update(Node);
StartPort = 2000;
EndPort = 3000;
await LazyLoader.Reload();
}
}