Archived
Private
Public Access
1
0

added mails page + reworked button placement

This commit is contained in:
2023-04-22 14:12:20 +02:00
parent a2149d24ec
commit c15df303f0
19 changed files with 560 additions and 50 deletions

View File

@@ -8,6 +8,7 @@
</PropertyGroup>
<ItemGroup>
<PackageReference Include="Aspose.Email" Version="23.3.0" />
<PackageReference Include="Microsoft.AspNetCore.OpenApi" Version="7.0.3" />
<PackageReference Include="Swashbuckle.AspNetCore" Version="6.4.0" />
<PackageReference Include="WebDav.Client" Version="2.8.0" />

View File

@@ -0,0 +1,105 @@
using System.Net;
using System.Net.Mail;
using System.Text;
using Aspose.Email.Clients.Imap;
using BetterIServ.Backend.Entities;
using Microsoft.AspNetCore.Mvc;
namespace BetterIServ.Backend.Controllers;
[ApiController]
[Route("mail")]
public class MailController : ControllerBase {
[HttpPost("send")]
public async Task<IActionResult> SendMail([FromBody] MailData data) {
using var client = new SmtpClient($"smpt.{data.Domain}");
var sender = new MailAddress($"{data.Username}@{data.Domain}", data.Username);
var reciever = new MailAddress(data.Receiver ?? $"{data.Username}@{data.Domain}");
using var message = new MailMessage(sender, reciever);
message.Body = data.MailBody;
message.Subject = data.Subject;
message.BodyEncoding = Encoding.UTF8;
message.SubjectEncoding = Encoding.UTF8;
var result = new TaskCompletionSource<IActionResult>();
client.SendCompleted += (o, args) => {
if (args is { Cancelled: false, Error: null })
result.SetResult(Ok());
else result.SetResult(BadRequest(args.Error?.Message));
};
client.Credentials = new NetworkCredential(data.Username, data.Password);
client.EnableSsl = true;
await client.SendMailAsync(message);
return await result.Task;
}
[HttpPost("list/{page}")]
public async Task<ActionResult<MailContent[]>> GetMails([FromBody] Credentials credentials, [FromQuery] string folder, [FromRoute] int page) {
using var client = new ImapClient($"imap.{credentials.Domain}", credentials.Username, credentials.Password);
await client.SelectFolderAsync(folder);
var messages = await client.ListMessagesByPageAsync(20, page, new PageSettingsAsync());
var contents = new List<MailContent>();
foreach (var message in messages.Items) {
var content = new MailContent {
Id = message.SequenceNumber,
Sender = message.Sender,
Subject = message.Subject,
Time = message.Date,
Read = message.IsRead
};
contents.Add(content);
}
return contents.ToArray();
}
[HttpPost("content/{id}")]
public async Task<ActionResult<MailContent>> GetMail([FromBody] Credentials credentials, [FromRoute] int id) {
using var client = new ImapClient($"imap.{credentials.Domain}", credentials.Username, credentials.Password);
var message = await client.FetchMessageAsync(id);
var content = new MailContent {
Id = id,
Sender = message.Sender,
Subject = message.Subject.Replace("(Aspose.Email Evaluation)", ""),
Time = message.Date,
Read = true,
Message = message.Body.Replace("EVALUATION ONLY. CREATED WITH ASPOSE.EMAIL FOR .NET. COPYRIGHT 2002-2022 ASPOSE PTY LTD. \r\n http://www.aspose.com/corporate/purchase/end-user-license-agreement.aspx: View EULA Online\r\n", ""),
Attachments = message.Attachments.Select(a => a.Name).ToArray()
};
return content;
}
[HttpPost("folder")]
public async Task<ActionResult<SingleResult<ImapFolderInfo[]>>> GetFolder([FromBody] Credentials credentials) {
using var client = new ImapClient($"imap.{credentials.Domain}", credentials.Username, credentials.Password);
var folders = await client.ListFoldersAsync();
var results = new List<ImapFolderInfo>();
foreach (var folder in folders) {
results.Add(folder);
if (folder.HasChildren) {
var children = await client.ListFoldersAsync(folder.Name);
results.AddRange(children);
}
}
return new SingleResult<ImapFolderInfo[]> { Value = results.ToArray() };
}
[HttpPost("download/{id}/{attachment}")]
public async Task<FileStreamResult> DownloadAttachment([FromBody] Credentials credentials, [FromRoute] int id, [FromRoute] string attachment) {
using var client = new ImapClient($"imap.{credentials.Domain}", credentials.Username, credentials.Password);
var data = await client.FetchAttachmentAsync(id, attachment);
return new FileStreamResult(data.ContentStream, "application/octet-stream") {
FileDownloadName = attachment
};
}
}

View File

@@ -1,7 +1,8 @@
namespace BetterIServ.Backend.Entities;
public struct Credentials {
public string Domain { get; set; }
public string Username { get; set; }
public string Password { get; set; }
public class Credentials {
public string? Domain { get; set; }
public string? Username { get; set; }
public string? Password { get; set; }
public string? Token { get; set; }
}

View File

@@ -0,0 +1,13 @@
using Aspose.Email;
namespace BetterIServ.Backend.Entities;
public struct MailContent {
public int Id { get; set; }
public MailAddress Sender { get; set; }
public string Subject { get; set; }
public string Message { get; set; }
public DateTime Time { get; set; }
public bool Read { get; set; }
public string[] Attachments { get; set; }
}

View File

@@ -0,0 +1,9 @@
namespace BetterIServ.Backend.Entities;
public sealed class MailData : Credentials {
public string? MailBody { get; set; }
public string? Receiver { get; set; }
public string? Subject { get; set; }
}

View File

@@ -0,0 +1,5 @@
namespace BetterIServ.Backend.Entities;
public class SingleResult<TValue> {
public TValue? Value { get; set; }
}