You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Zero/ZeroLevel/Services/Network/FileTransfer/FileServer.cs

52 lines
2.2 KiB

6 years ago
using System;
6 years ago
using ZeroLevel.Models;
6 years ago
6 years ago
namespace ZeroLevel.Network.FileTransfer
6 years ago
{
public sealed class FileServer
: BaseFileTransfer, IFileServer
{
private readonly IRouter _service;
6 years ago
private readonly string _baseFolder;
private readonly ServerFolderNameMapperDelegate _nameMapper;
private readonly bool _disposeService;
internal FileServer(IRouter service, string baseFolder, ServerFolderNameMapperDelegate nameMapper, bool disposeService)
6 years ago
: base(baseFolder)
{
_service = service ?? throw new Exception(nameof(service));
_baseFolder = baseFolder ?? throw new Exception(nameof(baseFolder));
_nameMapper = nameMapper ?? throw new Exception(nameof(nameMapper));
_disposeService = disposeService;
_service.RegisterInbox<FileStartFrame, InvokeResult>("__upload_file_start", (client, f) => Receiver.Incoming(f, nameMapper(client)));
_service.RegisterInbox<FileFrame, InvokeResult>("__upload_file_frame", (client, f) => Receiver.Incoming(f));
_service.RegisterInbox<FileEndFrame, InvokeResult>("__upload_file_complete", (client, f) => Receiver.Incoming(f));
6 years ago
}
public void Send(ExClient client, string fileName, Action<string> completeHandler = null, Action<string, string> errorHandler = null)
6 years ago
{
PushTransferTask(fileName, completeHandler, errorHandler, client);
}
internal override void ExecuteSendFile(FileReader reader, FileTransferTask task)
{
Log.Info($"Start upload file {reader.Path}");
var startinfo = reader.GetStartInfo();
if (false == task.Client.Send<FileStartFrame>("__upload_file_start", startinfo).Success)
6 years ago
{
6 years ago
return;
}
foreach (var chunk in reader.Read())
{
if (task.Client.Send<FileFrame>("__upload_file_frame", chunk).Success == false)
{
6 years ago
return;
}
6 years ago
}
task.Client.Send<FileEndFrame>("__upload_file_complete", reader.GetCompleteInfo());
6 years ago
Log.Debug($"Stop upload file {reader.Path}");
6 years ago
}
}
}

Powered by TurnKey Linux.