Resolve merge conflicts
This commit is contained in:
parent
875e846470
commit
dc479a35a8
@ -1,10 +0,0 @@
|
|||||||
{
|
|
||||||
"profiles": {
|
|
||||||
"Squirrowse.Client": {
|
|
||||||
"commandName": "Project",
|
|
||||||
"environmentVariables": {
|
|
||||||
"DOTNET_ENVIRONMENT": "Development"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,61 +0,0 @@
|
|||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
using Microsoft.AspNetCore.SignalR.Client;
|
|
||||||
using Microsoft.Extensions.Logging;
|
|
||||||
using Squirrowse.Core.Models;
|
|
||||||
using Squirrowse.Core.Services;
|
|
||||||
|
|
||||||
namespace Squirrowse.Client.Service
|
|
||||||
{
|
|
||||||
public class ActionDispatcher : IActionDispatcher
|
|
||||||
{
|
|
||||||
private readonly ICameraService camera;
|
|
||||||
private readonly IConnectionManager connectionManager;
|
|
||||||
private readonly ILogger<ActionDispatcher> logger;
|
|
||||||
private readonly HubConnection session;
|
|
||||||
private bool streamOn = false;
|
|
||||||
public ActionDispatcher(ILogger<ActionDispatcher> logger, IConnectionManager connectionManager,
|
|
||||||
ICameraService camera)
|
|
||||||
{
|
|
||||||
this.connectionManager = connectionManager;
|
|
||||||
this.logger = logger;
|
|
||||||
this.camera = camera;
|
|
||||||
session = connectionManager.GetConnection().Result;
|
|
||||||
session.On("Start", StartStream);
|
|
||||||
//session.On("StartEnum", StartStreamEnumerable);
|
|
||||||
session.On("Stop", StopStream);
|
|
||||||
}
|
|
||||||
|
|
||||||
public Task StopStream()
|
|
||||||
{
|
|
||||||
streamOn = false;
|
|
||||||
return Task.CompletedTask;
|
|
||||||
}
|
|
||||||
|
|
||||||
public async Task SayHello()
|
|
||||||
{
|
|
||||||
await session.SendAsync("AddToGroup", Groups.debug);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async Task SendStreamAsync(IAsyncEnumerable<byte[]> asb)
|
|
||||||
{
|
|
||||||
if(!streamOn)return;
|
|
||||||
logger.LogInformation($"{nameof(SendStreamAsync)} Start stream");
|
|
||||||
|
|
||||||
await session.SendAsync("UploadByteStream", asb);
|
|
||||||
|
|
||||||
logger.LogInformation($"{nameof(SendStreamAsync)} End stream");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public async Task StartStream()
|
|
||||||
{
|
|
||||||
if (streamOn) return;
|
|
||||||
streamOn = true;
|
|
||||||
await SendStreamAsync(camera.GetFramesAsyncEnumerator());
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,29 +0,0 @@
|
|||||||
using OpenCvSharp;
|
|
||||||
|
|
||||||
namespace Squirrowse.Client.Service
|
|
||||||
{
|
|
||||||
public class Camera : CameraFactory
|
|
||||||
{
|
|
||||||
private readonly bool Disposable;
|
|
||||||
private readonly double Fps;
|
|
||||||
private readonly int Height;
|
|
||||||
private readonly int Width;
|
|
||||||
|
|
||||||
public Camera(int height = 480, int width = 640, double fps = 30f)
|
|
||||||
{
|
|
||||||
Height = height;
|
|
||||||
Width = width;
|
|
||||||
Fps = fps;
|
|
||||||
}
|
|
||||||
|
|
||||||
public override VideoCapture GetCamera()
|
|
||||||
{
|
|
||||||
var cam = new VideoCapture(CaptureDevice.Any)
|
|
||||||
{
|
|
||||||
Fps = Fps, FrameHeight = Height, FrameWidth = Width
|
|
||||||
};
|
|
||||||
|
|
||||||
return cam;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,9 +0,0 @@
|
|||||||
using OpenCvSharp;
|
|
||||||
|
|
||||||
namespace Squirrowse.Client.Service
|
|
||||||
{
|
|
||||||
public abstract class CameraFactory
|
|
||||||
{
|
|
||||||
public abstract VideoCapture GetCamera();
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,35 +0,0 @@
|
|||||||
using System.Collections.Generic;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
using OpenCvSharp;
|
|
||||||
using Squirrowse.Core.Services;
|
|
||||||
|
|
||||||
namespace Squirrowse.Client.Service
|
|
||||||
{
|
|
||||||
public class CameraService : ICameraService
|
|
||||||
{
|
|
||||||
private readonly VideoCapture _videoCapture;
|
|
||||||
|
|
||||||
public CameraService(CameraFactory cam)
|
|
||||||
{
|
|
||||||
_videoCapture = cam.GetCamera();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public async Task<Mat> GetFrame()
|
|
||||||
{
|
|
||||||
var video = _videoCapture.RetrieveMat();
|
|
||||||
return video;
|
|
||||||
}
|
|
||||||
|
|
||||||
public async IAsyncEnumerable<byte[]> GetFramesAsyncEnumerator()
|
|
||||||
{
|
|
||||||
while (true)
|
|
||||||
{
|
|
||||||
using var fr = await GetFrame();
|
|
||||||
yield return fr.ConvertToJpgByte();
|
|
||||||
await Task.Delay(1000 / 30);
|
|
||||||
}
|
|
||||||
//fr.Dispose();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,13 +0,0 @@
|
|||||||
using System.Collections.Generic;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
|
|
||||||
namespace Squirrowse.Client.Service
|
|
||||||
{
|
|
||||||
public interface IActionDispatcher
|
|
||||||
{
|
|
||||||
Task SendStreamAsync(IAsyncEnumerable<byte[]> asb);
|
|
||||||
Task StartStream();
|
|
||||||
Task StopStream();
|
|
||||||
Task SayHello();
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,12 +0,0 @@
|
|||||||
using System.Collections.Generic;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
using OpenCvSharp;
|
|
||||||
|
|
||||||
namespace Squirrowse.Client.Service
|
|
||||||
{
|
|
||||||
public interface ICameraService
|
|
||||||
{
|
|
||||||
Task<Mat> GetFrame();
|
|
||||||
IAsyncEnumerable<byte[]> GetFramesAsyncEnumerator();
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,11 +0,0 @@
|
|||||||
{
|
|
||||||
"Logging": {
|
|
||||||
"LogLevel": {
|
|
||||||
"Default": "Debug",
|
|
||||||
"System": "Information",
|
|
||||||
"Microsoft": "Information",
|
|
||||||
"Microsoft.AspNetCore.SignalR": "Debug",
|
|
||||||
"Microsoft.AspNetCore.Http.Connections": "Debug"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,9 +0,0 @@
|
|||||||
{
|
|
||||||
"Logging": {
|
|
||||||
"LogLevel": {
|
|
||||||
"Default": "Information",
|
|
||||||
"Microsoft": "Warning",
|
|
||||||
"Microsoft.Hosting.Lifetime": "Information"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,34 +0,0 @@
|
|||||||
using FluentAssertions;
|
|
||||||
using OpenCvSharp;
|
|
||||||
using Squirrowse.Core.Services;
|
|
||||||
using Xunit;
|
|
||||||
|
|
||||||
namespace Squirrowse.Core.Tests
|
|
||||||
{
|
|
||||||
public class ImgExtensionTests
|
|
||||||
{
|
|
||||||
private readonly Mat sampleMat = new Mat(500, 600, MatType.CV_8UC3);
|
|
||||||
|
|
||||||
[SkippableFact]
|
|
||||||
public void ByteShouldBeConvertedToMat()
|
|
||||||
{
|
|
||||||
//
|
|
||||||
Skip.If(true, "Cannot use fluent assertion in this kind of test (compare pointer to obj)");
|
|
||||||
//
|
|
||||||
var bytes = sampleMat.ConvertToJpgByte();
|
|
||||||
|
|
||||||
var reMet = bytes.ConvertByteToMat();
|
|
||||||
|
|
||||||
reMet.Should().BeEquivalentTo(sampleMat);
|
|
||||||
}
|
|
||||||
|
|
||||||
[Fact]
|
|
||||||
public void MatShouldBeConvertedToByteArr()
|
|
||||||
{
|
|
||||||
var newByteArr = sampleMat.ConvertToJpgByte();
|
|
||||||
|
|
||||||
newByteArr.Should().BeOfType(typeof(byte[]));
|
|
||||||
newByteArr.Should().NotBeNullOrEmpty();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,23 +0,0 @@
|
|||||||
<Project Sdk="Microsoft.NET.Sdk">
|
|
||||||
|
|
||||||
<PropertyGroup>
|
|
||||||
<TargetFramework>netcoreapp3.0</TargetFramework>
|
|
||||||
|
|
||||||
<IsPackable>false</IsPackable>
|
|
||||||
</PropertyGroup>
|
|
||||||
|
|
||||||
<ItemGroup>
|
|
||||||
<PackageReference Include="FluentAssertions" Version="5.9.0" />
|
|
||||||
<PackageReference Include="Microsoft.NET.Test.Sdk" Version="16.2.0" />
|
|
||||||
<PackageReference Include="xunit" Version="2.4.0" />
|
|
||||||
<PackageReference Include="xunit.runner.visualstudio" Version="2.4.0" />
|
|
||||||
<PackageReference Include="coverlet.collector" Version="1.0.1" />
|
|
||||||
<PackageReference Include="OpenCvSharp4.Windows" Version="4.1.1.20191021" />
|
|
||||||
<PackageReference Include="Xunit.SkippableFact" Version="1.3.12" />
|
|
||||||
</ItemGroup>
|
|
||||||
|
|
||||||
<ItemGroup>
|
|
||||||
<ProjectReference Include="..\Squirrowse.Core\Squirrowse.Core.csproj" />
|
|
||||||
</ItemGroup>
|
|
||||||
|
|
||||||
</Project>
|
|
@ -1,17 +0,0 @@
|
|||||||
using Microsoft.Extensions.DependencyInjection;
|
|
||||||
using Microsoft.Extensions.Logging;
|
|
||||||
using Squirrowse.Core.Services;
|
|
||||||
|
|
||||||
namespace Squirrowse.Core
|
|
||||||
{
|
|
||||||
public static class CoreModule
|
|
||||||
{
|
|
||||||
public static IServiceCollection AddCoreModule(this IServiceCollection services)
|
|
||||||
{
|
|
||||||
services.AddSingleton(typeof(ILogger<>), typeof(Logger<>));
|
|
||||||
services.AddSingleton<IConnectionManager, ConnectionManager>(x =>
|
|
||||||
new ConnectionManager("http://localhost", 5000));
|
|
||||||
return services;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,10 +0,0 @@
|
|||||||
namespace Squirrowse.Core.Models
|
|
||||||
{
|
|
||||||
public enum ConnectionType
|
|
||||||
{
|
|
||||||
Unknown = -1,
|
|
||||||
Client,
|
|
||||||
Server,
|
|
||||||
Root
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,9 +0,0 @@
|
|||||||
namespace Squirrowse.Core.Models
|
|
||||||
{
|
|
||||||
public enum Groups
|
|
||||||
{
|
|
||||||
debug = -1,
|
|
||||||
normal,
|
|
||||||
superUser
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,16 +0,0 @@
|
|||||||
namespace Squirrowse.Core.Models
|
|
||||||
{
|
|
||||||
public class User
|
|
||||||
{
|
|
||||||
public User(string connectionId, string agentName, ConnectionType userType)
|
|
||||||
{
|
|
||||||
ConnectionId = connectionId;
|
|
||||||
AgentName = agentName;
|
|
||||||
UserType = userType;
|
|
||||||
}
|
|
||||||
|
|
||||||
public string ConnectionId { get; set; }
|
|
||||||
public string AgentName { get; set; }
|
|
||||||
public ConnectionType UserType { get; set; }
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,14 +0,0 @@
|
|||||||
using Squirrowse.Core.Models;
|
|
||||||
using System;
|
|
||||||
|
|
||||||
namespace Squirrowse.Client.Models
|
|
||||||
{
|
|
||||||
public class VStream
|
|
||||||
{
|
|
||||||
public User user { get; set; }
|
|
||||||
public byte[] FrameBytes { get; set; }
|
|
||||||
public DateTime TimeStamp => DateTime.Now;
|
|
||||||
public Guid id => Guid.NewGuid();
|
|
||||||
public string Issuer { get; set; }
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,51 +0,0 @@
|
|||||||
using System;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
using Microsoft.AspNetCore.SignalR.Client;
|
|
||||||
using Microsoft.Extensions.DependencyInjection;
|
|
||||||
using Squirrowse.Core.Models;
|
|
||||||
|
|
||||||
namespace Squirrowse.Core.Services
|
|
||||||
{
|
|
||||||
public class ConnectionManager : IConnectionManager
|
|
||||||
{
|
|
||||||
private readonly HubConnection _connection;
|
|
||||||
private bool Connected;
|
|
||||||
|
|
||||||
public ConnectionManager(string url, int port)
|
|
||||||
{
|
|
||||||
_connection = new HubConnectionBuilder()
|
|
||||||
.WithUrl($"{url}:{port}/StreamHub")
|
|
||||||
.AddMessagePackProtocol()
|
|
||||||
.WithAutomaticReconnect()
|
|
||||||
.Build();
|
|
||||||
}
|
|
||||||
|
|
||||||
public async Task<HubConnection> GetConnection()
|
|
||||||
{
|
|
||||||
return _connection;
|
|
||||||
}
|
|
||||||
|
|
||||||
public async Task InitConnection(ConnectionType type)
|
|
||||||
{
|
|
||||||
if (_connection.State == HubConnectionState.Connected) return;
|
|
||||||
if (_connection.State == HubConnectionState.Disconnected) await _connection.StartAsync();
|
|
||||||
|
|
||||||
await RegisterOnHub(type);
|
|
||||||
Connected = true;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public async Task Disconnect()
|
|
||||||
{
|
|
||||||
if (_connection.State == HubConnectionState.Disconnected) throw new Exception();
|
|
||||||
await _connection.StopAsync();
|
|
||||||
Connected = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
private async Task RegisterOnHub(ConnectionType type)
|
|
||||||
{
|
|
||||||
await _connection.SendAsync("AddUser", Environment.UserName, type);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,13 +0,0 @@
|
|||||||
using System.Threading.Tasks;
|
|
||||||
using Microsoft.AspNetCore.SignalR.Client;
|
|
||||||
using Squirrowse.Core.Models;
|
|
||||||
|
|
||||||
namespace Squirrowse.Core.Services
|
|
||||||
{
|
|
||||||
public interface IConnectionManager
|
|
||||||
{
|
|
||||||
Task<HubConnection> GetConnection();
|
|
||||||
Task InitConnection(ConnectionType type);
|
|
||||||
Task Disconnect();
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,20 +0,0 @@
|
|||||||
using System.Linq;
|
|
||||||
using OpenCvSharp;
|
|
||||||
|
|
||||||
namespace Squirrowse.Core.Services
|
|
||||||
{
|
|
||||||
public static class ImgExtensions
|
|
||||||
{
|
|
||||||
public static byte[] ConvertToJpgByte(this Mat mat)
|
|
||||||
{
|
|
||||||
Cv2.ImEncode(".jpg", mat, out var imgbuffer); //no need to dispose
|
|
||||||
return imgbuffer.Any() ? imgbuffer : new byte[] { };
|
|
||||||
}
|
|
||||||
|
|
||||||
public static Mat ConvertByteToMat(this byte[] bytearr)
|
|
||||||
{
|
|
||||||
var tempMat = Cv2.ImDecode(bytearr, ImreadModes.Unchanged); //keep as disposable
|
|
||||||
return tempMat ?? new Mat();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,21 +0,0 @@
|
|||||||
FROM mcr.microsoft.com/dotnet/core/aspnet:3.0-buster-slim AS base
|
|
||||||
WORKDIR /app
|
|
||||||
EXPOSE 5000
|
|
||||||
EXPOSE 5001
|
|
||||||
|
|
||||||
FROM mcr.microsoft.com/dotnet/core/sdk:3.0-buster AS build
|
|
||||||
WORKDIR /src
|
|
||||||
COPY ["Squirrowse.Service/Squirrowse.Service.csproj", "Squirrowse.Service/"]
|
|
||||||
COPY ["Squirrowse.Core/Squirrowse.Core.csproj", "Squirrowse.Core/"]
|
|
||||||
RUN dotnet restore "Squirrowse.Service/Squirrowse.Service.csproj"
|
|
||||||
COPY . .
|
|
||||||
WORKDIR "/src/Squirrowse.Service"
|
|
||||||
RUN dotnet build "Squirrowse.Service.csproj" -c Release -o /app/build
|
|
||||||
|
|
||||||
FROM build AS publish
|
|
||||||
RUN dotnet publish "Squirrowse.Service.csproj" -c Release -o /app/publish
|
|
||||||
|
|
||||||
FROM base AS final
|
|
||||||
WORKDIR /app
|
|
||||||
COPY --from=publish /app/publish .
|
|
||||||
ENTRYPOINT ["dotnet", "Squirrowse.Service.dll"]
|
|
@ -1,19 +0,0 @@
|
|||||||
using System.Collections.Generic;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
using Squirrowse.Core.Models;
|
|
||||||
|
|
||||||
namespace Squirrowse.Service.Hubs
|
|
||||||
{
|
|
||||||
public interface IStreamHub
|
|
||||||
{
|
|
||||||
Task AddUser(string username, ConnectionType type);
|
|
||||||
Task UploadByteStream(IAsyncEnumerable<byte[]> stream);
|
|
||||||
Task Startstream(string userId);
|
|
||||||
Task StopStream(string userId);
|
|
||||||
Task ExecCommandOnAll(string command, object[] act); //gni
|
|
||||||
Task AddToGroup(Groups group, string user = "");
|
|
||||||
Task RemoveFromGroup(Groups group, string user = "");
|
|
||||||
Task<IEnumerable<User>> GetListOfTypeUser(ConnectionType t);
|
|
||||||
Task<IEnumerable<User>> GetAllUsers();
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,19 +0,0 @@
|
|||||||
using System.Collections.Generic;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
using Squirrowse.Core.Models;
|
|
||||||
|
|
||||||
namespace Squirrowse.Service.Hubs
|
|
||||||
{
|
|
||||||
public interface IStreamManager
|
|
||||||
{
|
|
||||||
Task AddUser(string connectionId, string agentName, ConnectionType type);
|
|
||||||
Task RemoveUserbyConnectionId(string connectionId);
|
|
||||||
Task RemoveUserByUserName(string agentName);
|
|
||||||
IEnumerable<User> getServerSideUsers();
|
|
||||||
bool CheckUser(string agentName);
|
|
||||||
IEnumerable<User> getClientSideUsers();
|
|
||||||
IEnumerable<User> getAllUsers();
|
|
||||||
|
|
||||||
Task SaveData(IAsyncEnumerable<byte[]> stream);
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,143 +0,0 @@
|
|||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Globalization;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
using Microsoft.AspNetCore.SignalR;
|
|
||||||
using Microsoft.Extensions.Logging;
|
|
||||||
using OpenCvSharp;
|
|
||||||
using Squirrowse.Core.Models;
|
|
||||||
using Squirrowse.Core.Services;
|
|
||||||
|
|
||||||
namespace Squirrowse.Service.Hubs
|
|
||||||
{
|
|
||||||
public class StreamHub : Hub, IStreamHub //fujka
|
|
||||||
{
|
|
||||||
private readonly ILogger<StreamHub> logger;
|
|
||||||
private readonly IStreamManager manager;
|
|
||||||
|
|
||||||
|
|
||||||
public StreamHub(ILogger<StreamHub> logger, IStreamManager manager)
|
|
||||||
{
|
|
||||||
this.logger = logger;
|
|
||||||
this.manager = manager;
|
|
||||||
}
|
|
||||||
|
|
||||||
public async Task AddUser(string UserName, ConnectionType type)
|
|
||||||
{
|
|
||||||
await manager.AddUser(Context.ConnectionId, UserName, type);
|
|
||||||
switch (type)
|
|
||||||
{
|
|
||||||
case ConnectionType.Client:
|
|
||||||
await AddToGroup(Core.Models.Groups.normal);
|
|
||||||
break;
|
|
||||||
case ConnectionType.Server:
|
|
||||||
await AddToGroup(Core.Models.Groups.superUser);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
logger.LogInformation($"{nameof(AddUser)}: {UserName} of {type}");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public async Task AddToGroup(Groups group, string user = "")
|
|
||||||
{
|
|
||||||
var connectionId = string.IsNullOrWhiteSpace(user) ? Context.ConnectionId : user;
|
|
||||||
await Groups.AddToGroupAsync(connectionId, group.ToString());
|
|
||||||
logger.LogInformation($"{nameof(AddToGroup)}: {connectionId} joined to {group}");
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// USE ONLY FOR DEBUG
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="act"></param>
|
|
||||||
/// <returns>DESTRUCTION</returns>
|
|
||||||
public async Task ExecCommandOnAll(string command, object[] act)
|
|
||||||
{
|
|
||||||
await Clients.All.SendCoreAsync(command, act);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async Task RemoveFromGroup(Groups group, string user = "")
|
|
||||||
{
|
|
||||||
var connectionId = string.IsNullOrWhiteSpace(user) ? Context.ConnectionId : user;
|
|
||||||
await Groups.RemoveFromGroupAsync(connectionId, group.ToString());
|
|
||||||
logger.LogInformation($"{nameof(AddToGroup)}: {connectionId} joined to {group}");
|
|
||||||
}
|
|
||||||
|
|
||||||
public async Task Startstream(string clientId)
|
|
||||||
{
|
|
||||||
streamOn = true;
|
|
||||||
//var client = Clients.Client(clientId);
|
|
||||||
await Clients.Groups(Core.Models.Groups.normal.ToString()).SendAsync("Start");
|
|
||||||
// await client.SendAsync("Start");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public async Task StopStream(string clientId)
|
|
||||||
{
|
|
||||||
streamOn = false;
|
|
||||||
//var client = Clients.Client(clientId);
|
|
||||||
// await Clients.Groups(Core.Models.Groups.normal.ToString()).SendAsync("Stop");
|
|
||||||
//await client.SendAsync("Stop");
|
|
||||||
}
|
|
||||||
|
|
||||||
public static bool streamOn { get; set; }
|
|
||||||
|
|
||||||
public async Task UploadByteStream(IAsyncEnumerable<byte[]> stream)
|
|
||||||
{
|
|
||||||
|
|
||||||
await foreach (var frame in stream)
|
|
||||||
{
|
|
||||||
// var frameStamp = frame.ConvertByteToMat();
|
|
||||||
// string timestamp = DateTime.UtcNow.ToString("yyyy-MM-dd HH:mm:ss.fff",
|
|
||||||
// CultureInfo.InvariantCulture);
|
|
||||||
// Cv2.PutText(frameStamp, timestamp, new Point(1, 480 / 2), HersheyFonts.HersheySimplex, 0.5f, Scalar.Red);
|
|
||||||
logger.LogInformation($"{this.GetHashCode()}: send frame");
|
|
||||||
|
|
||||||
//logger.LogInformation($"Got frame size: {frame.Length} ");
|
|
||||||
//if (!streamOn) continue;
|
|
||||||
// logger.LogInformation($"Send frame of size: {frame.Length} to {Core.Models.Groups.superUser.ToString()}");
|
|
||||||
var framewithTs = await AddTimestamp(frame);
|
|
||||||
await Clients.Groups(Core.Models.Groups.superUser.ToString()).SendAsync("RecData",framewithTs );
|
|
||||||
logger.LogInformation($"{this.GetHashCode()}: send data");
|
|
||||||
//await Task.Delay(100); //leave some delay for debug purpose
|
|
||||||
await Task.Delay(1000 / 30);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
public async Task StartRecord(string connectionId)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
public async Task StopRecord(string connectionId)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
public async Task<byte[]> AddTimestamp(byte[] framebytes)
|
|
||||||
{
|
|
||||||
|
|
||||||
var frameStamp = framebytes.ConvertByteToMat();
|
|
||||||
string timestamp = DateTime.UtcNow.ToString("yyyy-MM-dd HH:mm:ss.fff",
|
|
||||||
CultureInfo.InvariantCulture);
|
|
||||||
Cv2.PutText(frameStamp, timestamp, new Point(1, 480 / 2), HersheyFonts.HersheySimplex, 0.5f, Scalar.Red);
|
|
||||||
return frameStamp.ConvertToJpgByte();
|
|
||||||
}
|
|
||||||
|
|
||||||
public async Task<IEnumerable<User>> GetListOfTypeUser(ConnectionType t)
|
|
||||||
{
|
|
||||||
if (t == ConnectionType.Client) return manager.getClientSideUsers();
|
|
||||||
if (t == ConnectionType.Server) return manager.getServerSideUsers();
|
|
||||||
return manager.getAllUsers();
|
|
||||||
}
|
|
||||||
|
|
||||||
public async Task<IEnumerable<User>> GetAllUsers()
|
|
||||||
{
|
|
||||||
return manager.getAllUsers();
|
|
||||||
}
|
|
||||||
|
|
||||||
public async IAsyncEnumerable<User> GetListOfTypeUserAsync(ConnectionType t)
|
|
||||||
{
|
|
||||||
var client = await GetListOfTypeUser(t);
|
|
||||||
foreach (var va in client) yield return va;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,65 +0,0 @@
|
|||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
using OpenCvSharp;
|
|
||||||
using Squirrowse.Core.Models;
|
|
||||||
using Squirrowse.Core.Services;
|
|
||||||
|
|
||||||
namespace Squirrowse.Service.Hubs
|
|
||||||
{
|
|
||||||
public class StreamManager : IStreamManager
|
|
||||||
{
|
|
||||||
private readonly List<User> _users = new List<User>(); //temporary
|
|
||||||
public bool StreamOn { get; set; }
|
|
||||||
public Task AddUser(string connectionId, string userName, ConnectionType type)
|
|
||||||
{
|
|
||||||
_users.Add(new User(connectionId, userName, type));
|
|
||||||
return Task.CompletedTask;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Task RemoveUserbyConnectionId(string connectionId)
|
|
||||||
{
|
|
||||||
_users.Remove(_users.First(user => user.ConnectionId == connectionId));
|
|
||||||
return Task.CompletedTask;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Task RemoveUserByUserName(string userName)
|
|
||||||
{
|
|
||||||
_users.RemoveAll(user => user.AgentName == userName);
|
|
||||||
return Task.CompletedTask;
|
|
||||||
}
|
|
||||||
|
|
||||||
public IEnumerable<User> getServerSideUsers()
|
|
||||||
{
|
|
||||||
return _users.Where(user => user.UserType == ConnectionType.Server);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public IEnumerable<User> getClientSideUsers()
|
|
||||||
{
|
|
||||||
return _users.Where(user => user.UserType == ConnectionType.Client);
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool CheckUser(string userName)
|
|
||||||
{
|
|
||||||
return _users.Any(user => user.AgentName == userName);
|
|
||||||
}
|
|
||||||
|
|
||||||
public IEnumerable<User> getAllUsers()
|
|
||||||
{
|
|
||||||
// var t = _users;
|
|
||||||
return _users;
|
|
||||||
}
|
|
||||||
|
|
||||||
public async Task SaveData(IAsyncEnumerable<byte[]> stream)
|
|
||||||
{
|
|
||||||
VideoWriter output = new VideoWriter("m.avi",FourCC.DIVX,30,new Size(640,480));
|
|
||||||
|
|
||||||
await foreach (var b in stream)
|
|
||||||
{
|
|
||||||
output.Write(b.ConvertByteToMat());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,66 +0,0 @@
|
|||||||
using System;
|
|
||||||
using System.IO;
|
|
||||||
using Microsoft.AspNetCore.Hosting;
|
|
||||||
using Microsoft.Extensions.Configuration;
|
|
||||||
using Microsoft.Extensions.Hosting;
|
|
||||||
using NLog;
|
|
||||||
using NLog.Extensions.Logging;
|
|
||||||
using NLog.Web;
|
|
||||||
|
|
||||||
namespace Squirrowse.Service
|
|
||||||
{
|
|
||||||
public class Program
|
|
||||||
{
|
|
||||||
public static IConfigurationRoot Configuration { get; set; }
|
|
||||||
|
|
||||||
public static void Main(string[] args)
|
|
||||||
{
|
|
||||||
Configuration = CreateConfigurationBuilder().Build();
|
|
||||||
var logger = GetLogger();
|
|
||||||
try
|
|
||||||
{
|
|
||||||
logger.Debug("Application started");
|
|
||||||
CreateHostBuilder(args)
|
|
||||||
.Build()
|
|
||||||
.Run();
|
|
||||||
}
|
|
||||||
catch (Exception ex)
|
|
||||||
{
|
|
||||||
logger.Error(ex, "Stopped program because of exception when building WebHost");
|
|
||||||
throw;
|
|
||||||
}
|
|
||||||
finally
|
|
||||||
{
|
|
||||||
LogManager.Shutdown();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static IHostBuilder CreateHostBuilder(string[] args)
|
|
||||||
{
|
|
||||||
return Host.CreateDefaultBuilder(args)
|
|
||||||
.ConfigureWebHostDefaults(webBuilder =>
|
|
||||||
{
|
|
||||||
webBuilder.UseStartup<Startup>();
|
|
||||||
webBuilder.UseConfiguration(Configuration);
|
|
||||||
webBuilder.UseNLog();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
private static IConfigurationBuilder CreateConfigurationBuilder()
|
|
||||||
{
|
|
||||||
var environment = Environment.GetEnvironmentVariable("ASPNETCORE_ENVIRONMENT");
|
|
||||||
return new ConfigurationBuilder()
|
|
||||||
.SetBasePath(Directory.GetCurrentDirectory())
|
|
||||||
.AddJsonFile("appsettings.json", false, true)
|
|
||||||
.AddJsonFile($"appsettings.{environment}.json", false, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static ILogger GetLogger()
|
|
||||||
{
|
|
||||||
var nlogConfigSection = Configuration.GetSection("NLog");
|
|
||||||
LogManager.Configuration = new NLogLoggingConfiguration(nlogConfigSection);
|
|
||||||
ILogger logger = LogManager.GetCurrentClassLogger();
|
|
||||||
return logger;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,40 +0,0 @@
|
|||||||
{
|
|
||||||
"iisSettings": {
|
|
||||||
"windowsAuthentication": false,
|
|
||||||
"anonymousAuthentication": true,
|
|
||||||
"iisExpress": {
|
|
||||||
"applicationUrl": "http://localhost:59337",
|
|
||||||
"sslPort": 44365
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"$schema": "http://json.schemastore.org/launchsettings.json",
|
|
||||||
"profiles": {
|
|
||||||
"IIS Express": {
|
|
||||||
"commandName": "IISExpress",
|
|
||||||
"environmentVariables": {
|
|
||||||
"ASPNETCORE_ENVIRONMENT": "Development"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"Squirrowse.Service": {
|
|
||||||
"commandName": "Project",
|
|
||||||
"launchBrowser": false,
|
|
||||||
"launchUrl": "weatherforecast",
|
|
||||||
"environmentVariables": {
|
|
||||||
"ASPNETCORE_ENVIRONMENT": "Development"
|
|
||||||
},
|
|
||||||
"applicationUrl": "https://localhost:5001;http://localhost:5000"
|
|
||||||
},
|
|
||||||
"Docker": {
|
|
||||||
"commandName": "Docker",
|
|
||||||
"launchBrowser": true,
|
|
||||||
"launchUrl": "{Scheme}://{ServiceHost}:{ServicePort}",
|
|
||||||
"environmentVariables": {
|
|
||||||
"ASPNETCORE_URLS": "https://+:443;http://+:80",
|
|
||||||
"ASPNETCORE_HTTPS_PORT": "44366"
|
|
||||||
},
|
|
||||||
"httpPort": 59338,
|
|
||||||
"useSSL": true,
|
|
||||||
"sslPort": 44366
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,28 +0,0 @@
|
|||||||
<Project Sdk="Microsoft.NET.Sdk.Web">
|
|
||||||
|
|
||||||
<PropertyGroup>
|
|
||||||
<TargetFramework>netcoreapp3.0</TargetFramework>
|
|
||||||
<UserSecretsId>996aee3a-63a2-4e6b-abcd-b0c6a183af8c</UserSecretsId>
|
|
||||||
<DockerDefaultTargetOS>Linux</DockerDefaultTargetOS>
|
|
||||||
</PropertyGroup>
|
|
||||||
|
|
||||||
<ItemGroup>
|
|
||||||
<Folder Include="Controllers\" />
|
|
||||||
</ItemGroup>
|
|
||||||
|
|
||||||
<ItemGroup>
|
|
||||||
<PackageReference Include="MediatR" Version="7.0.0" />
|
|
||||||
<PackageReference Include="MediatR.Extensions.Microsoft.DependencyInjection" Version="7.0.0" />
|
|
||||||
<PackageReference Include="Microsoft.AspNetCore.App" Version="3.0.0-*" />
|
|
||||||
<PackageReference Include="Microsoft.AspNetCore.SignalR.Protocols.MessagePack" Version="3.0.0" />
|
|
||||||
<PackageReference Include="Microsoft.VisualStudio.Azure.Containers.Tools.Targets" Version="1.9.5" />
|
|
||||||
<PackageReference Include="NLog.Web.AspNetCore" Version="4.9.0" />
|
|
||||||
<PackageReference Include="System.Reactive.Linq" Version="4.0.0" />
|
|
||||||
<PackageReference Include="OpenCvSharp4.Windows" Version="4.1.1.20191021" />
|
|
||||||
</ItemGroup>
|
|
||||||
|
|
||||||
<ItemGroup>
|
|
||||||
<ProjectReference Include="..\Squirrowse.Core\Squirrowse.Core.csproj" />
|
|
||||||
</ItemGroup>
|
|
||||||
|
|
||||||
</Project>
|
|
@ -1,54 +0,0 @@
|
|||||||
using System.Reflection;
|
|
||||||
using MediatR;
|
|
||||||
using Microsoft.AspNetCore.Builder;
|
|
||||||
using Microsoft.AspNetCore.Hosting;
|
|
||||||
using Microsoft.Extensions.Configuration;
|
|
||||||
using Microsoft.Extensions.DependencyInjection;
|
|
||||||
using Microsoft.Extensions.Hosting;
|
|
||||||
using Squirrowse.Core;
|
|
||||||
using Squirrowse.Service.Hubs;
|
|
||||||
|
|
||||||
namespace Squirrowse.Service
|
|
||||||
{
|
|
||||||
public class Startup
|
|
||||||
{
|
|
||||||
public Startup(IConfiguration configuration)
|
|
||||||
{
|
|
||||||
Configuration = configuration;
|
|
||||||
}
|
|
||||||
|
|
||||||
public IConfiguration Configuration { get; }
|
|
||||||
|
|
||||||
// This method gets called by the runtime. Use this method to add services to the container.
|
|
||||||
public void ConfigureServices(IServiceCollection services)
|
|
||||||
{
|
|
||||||
services.AddControllers();
|
|
||||||
services.AddMediatR(Assembly.GetAssembly(typeof(Startup)));
|
|
||||||
//services.AddSingleton<IStreamHub, StreamHub>();
|
|
||||||
services.AddSingleton<IStreamManager, StreamManager>();
|
|
||||||
services.AddCoreModule();
|
|
||||||
services.AddSignalR()
|
|
||||||
.AddHubOptions<StreamHub
|
|
||||||
>(opt => opt.MaximumReceiveMessageSize = 102400000) //~100mb per frame instead of 32kb default
|
|
||||||
.AddMessagePackProtocol();
|
|
||||||
}
|
|
||||||
|
|
||||||
// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
|
|
||||||
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
|
|
||||||
{
|
|
||||||
if (env.IsDevelopment()) app.UseDeveloperExceptionPage();
|
|
||||||
|
|
||||||
app.UseHttpsRedirection();
|
|
||||||
|
|
||||||
app.UseRouting();
|
|
||||||
|
|
||||||
app.UseAuthorization();
|
|
||||||
|
|
||||||
app.UseEndpoints(endpoints =>
|
|
||||||
{
|
|
||||||
endpoints.MapControllers();
|
|
||||||
endpoints.MapHub<StreamHub>($"{nameof(StreamHub)}");
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,11 +0,0 @@
|
|||||||
{
|
|
||||||
"Logging": {
|
|
||||||
"LogLevel": {
|
|
||||||
"Default": "Debug",
|
|
||||||
"System": "Information",
|
|
||||||
"Microsoft": "Information",
|
|
||||||
"Microsoft.AspNetCore.SignalR": "Debug",
|
|
||||||
"Microsoft.AspNetCore.Http.Connections": "Debug"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,43 +0,0 @@
|
|||||||
{
|
|
||||||
"Logging": {
|
|
||||||
"LogLevel": {
|
|
||||||
"Default": "Information",
|
|
||||||
"Microsoft": "Warning",
|
|
||||||
"Microsoft.Hosting.Lifetime": "Information",
|
|
||||||
"Microsoft.AspNetCore.SignalR": "Debug",
|
|
||||||
"Microsoft.AspNetCore.Http.Connections": "Debug"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"NLog": {
|
|
||||||
"autoreload": true,
|
|
||||||
"throwConfigExceptions": true,
|
|
||||||
"variables": {
|
|
||||||
"logDirectory": "${basedir}/logs"
|
|
||||||
},
|
|
||||||
"targets": {
|
|
||||||
"FileLogger": {
|
|
||||||
"type": "AsyncWrapper",
|
|
||||||
"target": {
|
|
||||||
"wrappedFile": {
|
|
||||||
"type": "File",
|
|
||||||
"fileName": "${logDirectory}/${machinename}.Log.txt",
|
|
||||||
"layout": "${longdate} ${level}: ${message} ${exception:format=tostring}",
|
|
||||||
"archiveFileName": "${logDirectory}/archives/${machinename}.Log_{#}.txt",
|
|
||||||
"archiveDateFormat": "yyyy-MM-dd",
|
|
||||||
"archiveAboveSize": "5242880",
|
|
||||||
"archiveEvery": "Day",
|
|
||||||
"archiveNumbering": "DateAndSequence",
|
|
||||||
"maxArchiveFiles": "90"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"rules": [
|
|
||||||
{
|
|
||||||
"logger": "*",
|
|
||||||
"writeTo": "FileLogger"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"AllowedHosts": "*"
|
|
||||||
}
|
|
Binary file not shown.
Binary file not shown.
Binary file not shown.
@ -1,136 +0,0 @@
|
|||||||
@page "/hub"
|
|
||||||
|
|
||||||
<h3>Hub</h3>
|
|
||||||
|
|
||||||
@using System.Collections
|
|
||||||
@using Microsoft.AspNetCore.SignalR.Client
|
|
||||||
@using Squirrowse.Core.Models
|
|
||||||
@using Squirrowse.Core.Services
|
|
||||||
@inject IConnectionManager _connection;
|
|
||||||
|
|
||||||
@*<button id="LoadData"class="btn btn-success btn-sm" @onclick="@(() => loadData())">dupa123 </button>*@
|
|
||||||
|
|
||||||
<div class="card border-primary mb-3" style="max-width: 20rem;">
|
|
||||||
@if (agents != null && agents.Any())
|
|
||||||
{
|
|
||||||
@foreach (var agent in agents)
|
|
||||||
{
|
|
||||||
<div class="card-body">
|
|
||||||
<div>
|
|
||||||
<h3 class="badge-primary">
|
|
||||||
@agent.AgentName -> @agent.UserType.ToString()
|
|
||||||
</h3>
|
|
||||||
<div style="padding-top:10px">
|
|
||||||
<button id="ViewCast" disabled="@(IsViewingCastOf(agent.AgentName))" class="btn btn-success btn-sm" @onclick="@(() => OnViewCastClicked(agent.ConnectionId))">
|
|
||||||
View cast
|
|
||||||
</button>
|
|
||||||
|
|
||||||
<button id="StopViewCast" disabled="@(IsViewingCastOf(agent.AgentName))" class="btn btn-warning btn-sm" @onclick="@(() => OnStopViewCastClicked(agent.ConnectionId))">
|
|
||||||
Stop cast
|
|
||||||
</button>
|
|
||||||
|
|
||||||
<button id="StartRecording" disabled="@(IsViewingCastOf(agent.AgentName))" class="btn btn-warning btn-sm" @onclick="@(() =>StartRecording(agent.ConnectionId))">
|
|
||||||
Stop cast
|
|
||||||
</button>
|
|
||||||
<button id="StartRecording" disabled="@(IsViewingCastOf(agent.AgentName))" class="btn btn-warning btn-sm" @onclick="@(() =>StopRecording(agent.ConnectionId))">
|
|
||||||
Stop cast
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
<div class="card-body">
|
|
||||||
<h3 class="card-header badge-warning">No Cams</h3>
|
|
||||||
</div>
|
|
||||||
}
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="border">
|
|
||||||
<img id='screenImage' src="@imageSource" />
|
|
||||||
</div>
|
|
||||||
@code{
|
|
||||||
|
|
||||||
private List<User> agents=new List<User>();
|
|
||||||
|
|
||||||
HubConnection connection;
|
|
||||||
string imageSource = null;
|
|
||||||
string CurrentViewCastAgent = null;
|
|
||||||
|
|
||||||
protected override async Task OnInitializedAsync()
|
|
||||||
{
|
|
||||||
await _connection.InitConnection(ConnectionType.Server);
|
|
||||||
connection = await _connection.GetConnection();
|
|
||||||
connection.On<byte[]>("RecData", OnStreamDataReceived);
|
|
||||||
|
|
||||||
await foreach (var user in connection.StreamAsync<User>("GetListOfTypeUserAsync", ConnectionType.Client).ConfigureAwait(false))
|
|
||||||
{
|
|
||||||
agents.Add(user);
|
|
||||||
this.StateHasChanged();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
bool IsViewingCastOf(string agentName)
|
|
||||||
{
|
|
||||||
return agentName == CurrentViewCastAgent;
|
|
||||||
}
|
|
||||||
async Task StartRecording(string agent)
|
|
||||||
{
|
|
||||||
await connection.SendAsync("StartRecord");
|
|
||||||
StateHasChanged();
|
|
||||||
}
|
|
||||||
async Task StopRecording(string agent)
|
|
||||||
{
|
|
||||||
await connection.SendAsync("StopRecord");
|
|
||||||
StateHasChanged();
|
|
||||||
}
|
|
||||||
|
|
||||||
async Task OnStreamDataReceived(byte[] streamData)
|
|
||||||
{
|
|
||||||
//await foreach (var t in streamData)
|
|
||||||
//{
|
|
||||||
// var base64 = Convert.ToBase64String(t);
|
|
||||||
// imageSource = String.Format("data:image/jpg;base64,{0}", base64);
|
|
||||||
// StateHasChanged();
|
|
||||||
//}
|
|
||||||
|
|
||||||
var base64 = Convert.ToBase64String(streamData);
|
|
||||||
imageSource = String.Format("data:image/jpg;base64,{0}", base64);
|
|
||||||
StateHasChanged();
|
|
||||||
|
|
||||||
}
|
|
||||||
async Task OnStreamDataReceivedEn(byte[] streamData)
|
|
||||||
{
|
|
||||||
//await foreach (var t in streamData)
|
|
||||||
//{
|
|
||||||
// var base64 = Convert.ToBase64String(t);
|
|
||||||
// imageSource = String.Format("data:image/jpg;base64,{0}", base64);
|
|
||||||
// StateHasChanged();
|
|
||||||
//}
|
|
||||||
|
|
||||||
var base64 = Convert.ToBase64String(streamData);
|
|
||||||
imageSource = String.Format("data:image/jpg;base64,{0}", base64);
|
|
||||||
StateHasChanged();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
private async Task OnViewCastClicked(string agentName)
|
|
||||||
{
|
|
||||||
CurrentViewCastAgent = agentName;
|
|
||||||
await connection.InvokeAsync("Startstream", agentName);
|
|
||||||
StateHasChanged();
|
|
||||||
}
|
|
||||||
|
|
||||||
private async Task OnStopViewCastClicked(string agentName)
|
|
||||||
{
|
|
||||||
CurrentViewCastAgent = null;
|
|
||||||
await connection.InvokeAsync("StopStream", agentName);
|
|
||||||
imageSource = null;
|
|
||||||
StateHasChanged();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -19,7 +19,6 @@ namespace squirrowse.web.Data
|
|||||||
public async Task<List<string>> tags()
|
public async Task<List<string>> tags()
|
||||||
{
|
{
|
||||||
var tlist = new List<string>();
|
var tlist = new List<string>();
|
||||||
// using var db = new LiteDatabase("db.db");
|
|
||||||
var t = db.GetCollection<Frame>();
|
var t = db.GetCollection<Frame>();
|
||||||
|
|
||||||
foreach (var frame in t.FindAll().Where(x => x.Objects != null))
|
foreach (var frame in t.FindAll().Where(x => x.Objects != null))
|
||||||
@ -34,7 +33,6 @@ namespace squirrowse.web.Data
|
|||||||
public async Task<Dictionary<string, List<Frame>>> galeryEntireView()
|
public async Task<Dictionary<string, List<Frame>>> galeryEntireView()
|
||||||
{
|
{
|
||||||
var tags = await this.tags();
|
var tags = await this.tags();
|
||||||
// using var db = new LiteDatabase("db.db");
|
|
||||||
var t = db.GetCollection<Frame>();
|
var t = db.GetCollection<Frame>();
|
||||||
var d = new Dictionary<string, List<Frame>>();
|
var d = new Dictionary<string, List<Frame>>();
|
||||||
|
|
||||||
@ -44,17 +42,11 @@ namespace squirrowse.web.Data
|
|||||||
var t2 = t1.Where(x => x.Objects.Any(y => y.ObjectProperty == tag));
|
var t2 = t1.Where(x => x.Objects.Any(y => y.ObjectProperty == tag));
|
||||||
d.Add(tag, t2.ToList());
|
d.Add(tag, t2.ToList());
|
||||||
}
|
}
|
||||||
|
|
||||||
//var temp = t.Query().Select(x => x.Objects.Where().ToArray();
|
|
||||||
|
|
||||||
// t.Find(x => x.Objects.Any(y => y.ObjectProperty == tag)).ForEach(x => { d.Add(tag, x); });
|
|
||||||
//d.Add(tag,temp);
|
|
||||||
return d;
|
return d;
|
||||||
}
|
}
|
||||||
|
|
||||||
public async Task<Dictionary<string, List<Frame>>> galerViewbyTag(List<string> tags)
|
public async Task<Dictionary<string, List<Frame>>> galerViewbyTag(List<string> tags)
|
||||||
{
|
{
|
||||||
// using var db = new LiteDatabase("db.db");
|
|
||||||
var t = db.GetCollection<Frame>();
|
var t = db.GetCollection<Frame>();
|
||||||
var d = new Dictionary<string, List<Frame>>();
|
var d = new Dictionary<string, List<Frame>>();
|
||||||
|
|
||||||
@ -64,11 +56,6 @@ namespace squirrowse.web.Data
|
|||||||
var t2 = t1.Where(x => x.Objects.Any(y => y.ObjectProperty == tag));
|
var t2 = t1.Where(x => x.Objects.Any(y => y.ObjectProperty == tag));
|
||||||
d.Add(tag, t2.ToList());
|
d.Add(tag, t2.ToList());
|
||||||
}
|
}
|
||||||
|
|
||||||
//var temp = t.Query().Select(x => x.Objects.Where().ToArray();
|
|
||||||
|
|
||||||
// t.Find(x => x.Objects.Any(y => y.ObjectProperty == tag)).ForEach(x => { d.Add(tag, x); });
|
|
||||||
//d.Add(tag,temp);
|
|
||||||
return d;
|
return d;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user