Merge pull request #328 from bkaankose/hotfix/LogsArchive

Fixing sharing logs
This commit is contained in:
Burak Kaan Köse
2024-08-21 13:58:39 +02:00
committed by GitHub
5 changed files with 60 additions and 48 deletions

View File

@@ -13,5 +13,6 @@
public const string ClientLogFile = "Client_.log";
public const string ServerLogFile = "Server_.log";
public const string LogArchiveFileName = "WinoLogs.zip";
}
}

View File

@@ -8,5 +8,13 @@ namespace Wino.Core.Domain.Interfaces
Task<string> CopyFileAsync(string sourceFilePath, string destinationFolderPath);
Task<Stream> GetFileStreamAsync(string folderPath, string fileName);
Task<string> GetFileContentByApplicationUriAsync(string resourcePath);
/// <summary>
/// Zips all existing logs and saves to picked destination folder.
/// </summary>
/// <param name="logsFolder">Folder path where logs are stored.</param>
/// <param name="destinationFolder">Target path to save the archive file.</param>
/// <returns>True if zip is created with at least one item, false if logs are not found.</returns>
Task<bool> SaveLogsToFolderAsync(string logsFolder, string destinationFolder);
}
}

View File

@@ -1,7 +1,9 @@
using System;
using System.IO;
using System.IO.Compression;
using System.Threading.Tasks;
using Windows.Storage;
using Wino.Core.Domain;
using Wino.Core.Domain.Interfaces;
namespace Wino.Core.UWP.Services
@@ -34,5 +36,27 @@ namespace Wino.Core.UWP.Services
return await createdFile.OpenStreamForWriteAsync();
}
public async Task<bool> SaveLogsToFolderAsync(string logsFolder, string destinationFolder)
{
var logFiles = Directory.GetFiles(logsFolder, "*.log");
if (logFiles.Length == 0) return false;
using var fileStream = await GetFileStreamAsync(destinationFolder, Constants.LogArchiveFileName);
using var archive = new ZipArchive(fileStream, ZipArchiveMode.Create, true);
foreach (var logFile in logFiles)
{
using FileStream logFileStream = File.Open(logFile, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);
var zipArchiveEntry = archive.CreateEntry(Path.GetFileName(logFile), CompressionLevel.Fastest);
using var zipStream = zipArchiveEntry.Open();
await logFileStream.CopyToAsync(zipStream);
}
return true;
}
}
}

View File

@@ -1,14 +1,13 @@
using System;
using System.IO;
using System.Threading.Tasks;
using CommunityToolkit.Mvvm.Input;
using Wino.Core.Domain;
using Wino.Core.Domain.Enums;
using Wino.Core.Domain.Interfaces;
using Wino.Core.Services;
namespace Wino.Mail.ViewModels
{
public class AboutPageViewModel : BaseViewModel
public partial class AboutPageViewModel : BaseViewModel
{
private readonly IStoreRatingService _storeRatingService;
private readonly INativeAppService _nativeAppService;
@@ -22,9 +21,6 @@ namespace Wino.Mail.ViewModels
public string PrivacyPolicyUrl => "https://www.winomail.app/privacy_policy.html";
public string PaypalUrl => "https://paypal.me/bkaankose?country.x=PL&locale.x=en_US";
public AsyncRelayCommand<object> NavigateCommand { get; set; }
public AsyncRelayCommand ShareWinoLogCommand { get; set; }
public AsyncRelayCommand ShareProtocolLogCommand { get; set; }
public IPreferencesService PreferencesService { get; }
public AboutPageViewModel(IStoreRatingService storeRatingService,
@@ -42,9 +38,6 @@ namespace Wino.Mail.ViewModels
_fileService = fileService;
PreferencesService = preferencesService;
NavigateCommand = new AsyncRelayCommand<object>(Navigate);
ShareWinoLogCommand = new AsyncRelayCommand(ShareWinoLogAsync);
ShareProtocolLogCommand = new AsyncRelayCommand(ShareProtocolLogAsync);
}
protected override void OnActivated()
@@ -70,35 +63,28 @@ namespace Wino.Mail.ViewModels
}
}
private Task ShareProtocolLogAsync()
=> SaveLogInternalAsync(ImapTestService.ProtocolLogFileName);
private Task ShareWinoLogAsync()
=> SaveLogInternalAsync(Constants.ClientLogFile);
private async Task SaveLogInternalAsync(string sourceFileName)
[RelayCommand]
private async Task ShareWinoLogAsync()
{
var appDataFolder = _appInitializerService.ApplicationDataFolderPath;
var logFile = Path.Combine(appDataFolder, sourceFileName);
if (!File.Exists(logFile))
{
DialogService.InfoBarMessage(Translator.Info_LogsNotFoundTitle, Translator.Info_LogsNotFoundMessage, Core.Domain.Enums.InfoBarMessageType.Warning);
return;
}
var selectedFolderPath = await DialogService.PickWindowsFolderAsync();
if (string.IsNullOrEmpty(selectedFolderPath)) return;
var copiedFilePath = await _fileService.CopyFileAsync(logFile, selectedFolderPath);
var areLogsSaved = await _fileService.SaveLogsToFolderAsync(appDataFolder, selectedFolderPath).ConfigureAwait(false);
var copiedFileName = Path.GetFileName(copiedFilePath);
DialogService.InfoBarMessage(Translator.Info_LogsSavedTitle, string.Format(Translator.Info_LogsSavedMessage, copiedFileName), Core.Domain.Enums.InfoBarMessageType.Success);
if (areLogsSaved)
{
DialogService.InfoBarMessage(Translator.Info_LogsSavedTitle, string.Format(Translator.Info_LogsSavedMessage, Constants.LogArchiveFileName), InfoBarMessageType.Success);
}
else
{
DialogService.InfoBarMessage(Translator.Info_LogsNotFoundTitle, Translator.Info_LogsNotFoundMessage, InfoBarMessageType.Error);
}
}
[RelayCommand]
private async Task Navigate(object url)
{
if (url is string stringUrl)

View File

@@ -61,9 +61,9 @@
</controls:SettingsCard.HeaderIcon>
<controls:SettingsCard.ActionIcon>
<PathIcon
HorizontalAlignment="Center"
VerticalAlignment="Center"
Data="{StaticResource OpenInNewWindowPathIcon}" />
HorizontalAlignment="Center"
VerticalAlignment="Center"
Data="{StaticResource OpenInNewWindowPathIcon}" />
</controls:SettingsCard.ActionIcon>
</controls:SettingsCard>
@@ -81,9 +81,9 @@
</controls:SettingsCard.HeaderIcon>
<controls:SettingsCard.ActionIcon>
<PathIcon
HorizontalAlignment="Center"
VerticalAlignment="Center"
Data="{StaticResource OpenInNewWindowPathIcon}" />
HorizontalAlignment="Center"
VerticalAlignment="Center"
Data="{StaticResource OpenInNewWindowPathIcon}" />
</controls:SettingsCard.ActionIcon>
</controls:SettingsCard>
@@ -98,9 +98,9 @@
</controls:SettingsCard.HeaderIcon>
<controls:SettingsCard.ActionIcon>
<PathIcon
HorizontalAlignment="Center"
VerticalAlignment="Center"
Data="{StaticResource OpenInNewWindowPathIcon}" />
HorizontalAlignment="Center"
VerticalAlignment="Center"
Data="{StaticResource OpenInNewWindowPathIcon}" />
</controls:SettingsCard.ActionIcon>
</controls:SettingsCard>
@@ -118,9 +118,9 @@
</controls:SettingsCard.HeaderIcon>
<controls:SettingsCard.ActionIcon>
<PathIcon
HorizontalAlignment="Center"
VerticalAlignment="Center"
Data="{StaticResource OpenInNewWindowPathIcon}" />
HorizontalAlignment="Center"
VerticalAlignment="Center"
Data="{StaticResource OpenInNewWindowPathIcon}" />
</controls:SettingsCard.ActionIcon>
</controls:SettingsCard>
@@ -135,17 +135,10 @@
<controls:SettingsExpander.Items>
<controls:SettingsCard Header="{x:Bind domain:Translator.SettingsEnableLogs_Title}" Description="{x:Bind domain:Translator.SettingsEnableLogs_Description}">
<StackPanel Orientation="Horizontal" Spacing="12">
<Button Content="Share" Command="{x:Bind ViewModel.ShareWinoLogCommand}" />
<Button Content="{x:Bind domain:Translator.Buttons_Share}" Command="{x:Bind ViewModel.ShareWinoLogCommand}" />
<ToggleSwitch IsOn="{x:Bind ViewModel.PreferencesService.IsLoggingEnabled, Mode=TwoWay}" />
</StackPanel>
</controls:SettingsCard>
<controls:SettingsCard Header="{x:Bind domain:Translator.SettingsEnableIMAPLogs_Title}" Description="{x:Bind domain:Translator.SettingsEnableIMAPLogs_Description}">
<StackPanel Orientation="Horizontal" Spacing="12">
<Button Content="{x:Bind domain:Translator.Buttons_Share}" Command="{x:Bind ViewModel.ShareProtocolLogCommand}" />
<ToggleSwitch IsOn="{x:Bind ViewModel.PreferencesService.IsMailkitProtocolLoggerEnabled, Mode=TwoWay}" />
</StackPanel>
</controls:SettingsCard>
</controls:SettingsExpander.Items>
</controls:SettingsExpander>