* Separation of messages. Introducing Wino.Messages library. * Wino.Server and Wino.Packaging projects. Enabling full trust for UWP and app service connection manager basics. * Remove debug code. * Enable generating assembly info to deal with unsupported os platform warnings. * Fix server-client connection. * UIMessage communication. Single instancing for server and re-connection mechanism on suspension. * Removed IWinoSynchronizerFactory from UWP project. * Removal of background task service from core. * Delegating changes to UI and triggering new background synchronization. * Fix build error. * Moved core lib messages to Messaging project. * Better client-server communication. Handling of requests in the server. New synchronizer factory in the server. * WAM broker and MSAL token caching for OutlookAuthenticator. Handling account creation for Outlook. * WinoServerResponse basics. * Delegating protocol activation for Gmail authenticator. * Adding margin to searchbox to match action bar width. * Move libraries into lib folder. * Storing base64 encoded mime on draft creation instead of MimeMessage object. Fixes serialization/deserialization issue with S.T.Json * Scrollbar adjustments * WınoExpander for thread expander layout ıssue. * Handling synchronizer state changes. * Double init on background activation. * FIxing packaging issues and new Wino Mail launcher protocol for activation from full thrust process. * Remove debug deserialization. * Remove debug code. * Making sure the server connection is established when the app is launched. * Thrust -> Trust string replacement... * Rename package to Wino Mail * Enable translated values in the server. * Fixed an issue where toast activation can't find the clicked mail after the folder is initialized. * Revert debug code. * Change server background sync to every 3 minute and Inbox only synchronization. * Revert google auth changes. * App preferences page. * Changing tray icon visibility on preference change. * Start the server with invisible tray icon if set to invisible. * Reconnect button on the title bar. * Handling of toast actions. * Enable x86 build for server during packaging. * Get rid of old background tasks and v180 migration. * Terminate client when Exit clicked in server. * Introducing SynchronizationSource to prevent notifying UI after server tick synchronization. * Remove confirmAppClose restricted capability and unused debug code in manifest. * Closing the reconnect info popup when reconnect is clicked. * Custom RetryHandler for OutlookSynchronizer and separating client/server logs. * Running server on Windows startup. * Fix startup exe. * Fix for expander list view item paddings. * Force full sync on app launch instead of Inbox. * Fix draft creation. * Fix an issue with custom folder sync logic. * Reporting back account sync progress from server. * Fix sending drafts and missing notifications for imap. * Changing imap folder sync requirements. * Retain file count is set to 3. * Disabled swipe gestures temporarily due to native crash with SwipeControl * Save all attachments implementation. * Localization for save all attachments button. * Fix logging dates for logs. * Fixing ARM64 build. * Add ARM64 build config to packaging project. * Comment out OutOfProcPDB for ARM64. * Hnadling GONE response for Outlook folder synchronization.
115 lines
5.6 KiB
C#
115 lines
5.6 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Threading.Tasks;
|
|
using MimeKit;
|
|
using Wino.Core.Domain.Entities;
|
|
using Wino.Core.Domain.Models.MailItem;
|
|
|
|
namespace Wino.Core.Domain.Interfaces
|
|
{
|
|
public interface IMailService
|
|
{
|
|
Task<MailCopy> GetSingleMailItemAsync(string mailCopyId, string remoteFolderId);
|
|
Task<MailCopy> GetSingleMailItemAsync(Guid uniqueMailId);
|
|
Task<MailCopy> CreateDraftAsync(MailAccount composerAccount, string generatedReplyMimeMessageBase64, MimeMessage replyingMimeMessage = null, IMailItem replyingMailItem = null);
|
|
Task<List<IMailItem>> FetchMailsAsync(MailListInitializationOptions options);
|
|
|
|
/// <summary>
|
|
/// Deletes all mail copies for all folders.
|
|
/// </summary>
|
|
/// <param name="accountId">Account to remove from</param>
|
|
/// <param name="mailCopyId">Mail copy id to remove.</param>
|
|
Task DeleteMailAsync(Guid accountId, string mailCopyId);
|
|
|
|
Task ChangeReadStatusAsync(string mailCopyId, bool isRead);
|
|
Task ChangeFlagStatusAsync(string mailCopyId, bool isFlagged);
|
|
|
|
Task CreateAssignmentAsync(Guid accountId, string mailCopyId, string remoteFolderId);
|
|
Task DeleteAssignmentAsync(Guid accountId, string mailCopyId, string remoteFolderId);
|
|
|
|
Task<bool> CreateMailAsync(Guid accountId, NewMailItemPackage package);
|
|
|
|
/// <summary>
|
|
/// Maps new mail item with the existing local draft copy.
|
|
/// In case of failure, it returns false.
|
|
/// Then synchronizers must insert a new mail item.
|
|
/// </summary>
|
|
/// <param name="accountId">Id of the account. It's important to map to the account since if the user use the same account with different providers, this call must map the correct one.</param>
|
|
/// <param name="localDraftCopyUniqueId">UniqueId of the local draft copy.</param>
|
|
/// <param name="newMailCopyId">New assigned remote mail item id.</param>
|
|
/// <param name="newDraftId">New assigned draft id if exists.</param>
|
|
/// <param name="newThreadId">New message's thread/conversation id.</param>
|
|
/// <returns>True if mapping is done. False if local copy doesn't exists.</returns>
|
|
Task<bool> MapLocalDraftAsync(Guid accountId, Guid localDraftCopyUniqueId, string newMailCopyId, string newDraftId, string newThreadId);
|
|
|
|
/// <summary>
|
|
/// Maps new mail item with the existing local draft copy.
|
|
///
|
|
/// </summary>
|
|
/// <param name="newMailCopyId"></param>
|
|
/// <param name="newDraftId"></param>
|
|
/// <param name="newThreadId"></param>
|
|
Task MapLocalDraftAsync(string newMailCopyId, string newDraftId, string newThreadId);
|
|
|
|
/// <summary>
|
|
/// Creates a draft message with the given options.
|
|
/// </summary>
|
|
/// <param name="accountId">Account to create draft for.</param>
|
|
/// <param name="options">Draft creation options.</param>
|
|
/// <returns>
|
|
/// Base64 encoded string of MimeMessage object.
|
|
/// This is mainly for serialization purposes.
|
|
/// </returns>
|
|
Task<string> CreateDraftMimeBase64Async(Guid accountId, DraftCreationOptions options);
|
|
Task UpdateMailAsync(MailCopy mailCopy);
|
|
|
|
/// <summary>
|
|
/// Gets the new inserted unread mails after the synchronization.
|
|
/// </summary>
|
|
/// <param name="accountId">Account id.</param>
|
|
/// <param name="downloadedMailCopyIds">
|
|
/// Mail ids that synchronizer tried to download. If there was an issue with the
|
|
/// Items that tried and actually downloaded may differ. This function will return only new inserted ones.
|
|
/// </param>
|
|
/// <returns>Newly inserted unread mails inside the Inbox folder.</returns>
|
|
Task<List<MailCopy>> GetDownloadedUnreadMailsAsync(Guid accountId, IEnumerable<string> downloadedMailCopyIds);
|
|
|
|
/// <summary>
|
|
/// Returns the account that this mail copy unique id is assigned.
|
|
/// Used in toast notification handler.
|
|
/// </summary>
|
|
/// <param name="uniqueMailId">Unique id of the mail item.</param>
|
|
/// <returns>Account that mail belongs to.</returns>
|
|
Task<MailAccount> GetMailAccountByUniqueIdAsync(Guid uniqueMailId);
|
|
|
|
/// <summary>
|
|
/// Checks whether the given mail copy id exists in the database.
|
|
/// Safely used for Outlook to prevent downloading the same mail twice.
|
|
/// For Gmail, it should be avoided since one mail may belong to multiple folders.
|
|
/// </summary>
|
|
/// <param name="mailCopyId">Native mail id of the message.</param>
|
|
Task<bool> IsMailExistsAsync(string mailCopyId);
|
|
|
|
/// <summary>
|
|
/// Returns all mails for given folder id.
|
|
/// </summary>
|
|
/// <param name="folderId">Folder id to get mails for</param>
|
|
Task<List<MailCopy>> GetMailsByFolderIdAsync(Guid folderId);
|
|
|
|
/// <summary>
|
|
/// Returns all unread mails for given folder id.
|
|
/// </summary>
|
|
/// <param name="folderId">Folder id to get unread mails for.</param>
|
|
Task<List<MailCopy>> GetUnreadMailsByFolderIdAsync(Guid folderId);
|
|
|
|
/// <summary>
|
|
/// Checks whether the mail exists in the folder.
|
|
/// When deciding Create or Update existing mail, we need to check if the mail exists in the folder.
|
|
/// </summary>
|
|
/// <param name="messageId">Message id</param>
|
|
/// <param name="folderId">Folder's local id.</param>
|
|
/// <returns>Whether mail exists in the folder or not.</returns>
|
|
Task<bool> IsMailExistsAsync(string mailCopyId, Guid folderId);
|
|
}
|
|
}
|