diff --git a/src/Plugins/BotSharp.Plugin.EmailHandler/BotSharp.Plugin.EmailHandler.csproj b/src/Plugins/BotSharp.Plugin.EmailHandler/BotSharp.Plugin.EmailHandler.csproj index 6323706ff..f5926a53a 100644 --- a/src/Plugins/BotSharp.Plugin.EmailHandler/BotSharp.Plugin.EmailHandler.csproj +++ b/src/Plugins/BotSharp.Plugin.EmailHandler/BotSharp.Plugin.EmailHandler.csproj @@ -11,21 +11,29 @@ - - + + + + - + PreserveNewest - + + PreserveNewest + + PreserveNewest PreserveNewest + + PreserveNewest + diff --git a/src/Plugins/BotSharp.Plugin.EmailHandler/EmailHandlerPlugin.cs b/src/Plugins/BotSharp.Plugin.EmailHandler/EmailHandlerPlugin.cs index 5063093b9..5d7ff586c 100644 --- a/src/Plugins/BotSharp.Plugin.EmailHandler/EmailHandlerPlugin.cs +++ b/src/Plugins/BotSharp.Plugin.EmailHandler/EmailHandlerPlugin.cs @@ -1,5 +1,6 @@ using BotSharp.Abstraction.Agents; using BotSharp.Abstraction.Settings; +using BotSharp.Plugin.EmailHandler.Providers; using Microsoft.Extensions.Configuration; namespace BotSharp.Plugin.EmailHandler @@ -16,11 +17,22 @@ public void RegisterDI(IServiceCollection services, IConfiguration config) services.AddScoped(provider => { var settingService = provider.GetRequiredService(); - return settingService.Bind("EmailHandler"); + return settingService.Bind("EmailSender"); }); - services.AddScoped(); + services.AddScoped(); + services.AddScoped(); services.AddScoped(); + + var emailReaderSettings = new EmailReaderSettings(); + config.Bind("EmailReader", emailReaderSettings); + services.AddScoped(provider => + { + var settingService = provider.GetRequiredService(); + return settingService.Bind("EmailReader"); + }); + services.AddSingleton(provider => emailReaderSettings); + services.AddScoped(); } } } diff --git a/src/Plugins/BotSharp.Plugin.EmailHandler/Functions/HandleEmailReaderFn.cs b/src/Plugins/BotSharp.Plugin.EmailHandler/Functions/HandleEmailReaderFn.cs new file mode 100644 index 000000000..121638e73 --- /dev/null +++ b/src/Plugins/BotSharp.Plugin.EmailHandler/Functions/HandleEmailReaderFn.cs @@ -0,0 +1,205 @@ +using BotSharp.Abstraction.Agents.Enums; +using BotSharp.Abstraction.Files; +using BotSharp.Abstraction.Messaging.Models.RichContent.Template; +using BotSharp.Abstraction.MLTasks; +using BotSharp.Core.Infrastructures; +using BotSharp.Plugin.EmailHandler.Models; +using BotSharp.Plugin.EmailHandler.Providers; +using MailKit; +using MailKit.Net.Imap; +using MailKit.Search; +using MailKit.Security; +using Microsoft.AspNetCore.Http; +using Microsoft.Extensions.Logging; +using MimeKit; + +namespace BotSharp.Plugin.EmailReader.Functions; + +public class HandleEmailReaderFn : IFunctionCallback +{ + public string Name => "handle_email_reader"; + public readonly static string PROMPT_SUMMARY = "Provide a text summary of the following content."; + public readonly static string RICH_CONTENT_SUMMARIZE = "is_email_summarize: true. messageId"; + public readonly static string RICH_CONTENT_READ_EMAIL = "Read the email by messageId"; + public readonly static string RICH_CONTENT_MARK_READ = "mark_as_read: true. messageId"; + public string Indication => "Handling email read"; + private readonly IServiceProvider _services; + private readonly ILogger _logger; + private readonly IHttpContextAccessor _context; + private readonly BotSharpOptions _options; + private readonly EmailReaderSettings _emailSettings; + private readonly IConversationStateService _state; + private readonly IEmailReader _emailProvider; + + public HandleEmailReaderFn(IServiceProvider services, + ILogger logger, + IHttpContextAccessor context, + BotSharpOptions options, + EmailReaderSettings emailPluginSettings, + IConversationStateService state, + IEmailReader emailProvider) + { + _services = services; + _logger = logger; + _context = context; + _options = options; + _emailSettings = emailPluginSettings; + _state = state; + _emailProvider = emailProvider; + } + public async Task Execute(RoleDialogModel message) + { + var args = JsonSerializer.Deserialize(message.FunctionArgs, _options.JsonSerializerOptions); + var isMarkRead = args?.IsMarkRead ?? false; + var isSummarize = args?.IsSummarize ?? false; + var messageId = args?.MessageId; + try + { + if (!string.IsNullOrEmpty(messageId)) + { + if (isMarkRead) + { + await _emailProvider.MarkEmailAsReadById(messageId); + message.Content = $"The email message has been marked as read."; + return true; + } + var emailMessage = await _emailProvider.GetEmailById(messageId); + if (isSummarize) + { + var prompt = $"{PROMPT_SUMMARY} The content was sent by {emailMessage.From.ToString()}. Details: {emailMessage.TextBody}"; + var agent = new Agent + { + Id = BuiltInAgentId.UtilityAssistant, + Name = "Utility Assistant", + Instruction = prompt + }; + + var llmProviderService = _services.GetRequiredService(); + var provider = llmProviderService.GetProviders().FirstOrDefault(x => x == "openai"); + var model = llmProviderService.GetProviderModel(provider: provider, id: "gpt-4"); + var completion = CompletionProvider.GetChatCompletion(_services, provider: provider, model: model.Name); + var convService = _services.GetService(); + var conversationId = convService.ConversationId; + var dialogs = convService.GetDialogHistory(fromBreakpoint: false); + var response = await completion.GetChatCompletions(agent, dialogs); + var content = response?.Content ?? string.Empty; + message.Content = content; + message.RichContent = BuildRichContentForSummary(_state.GetConversationId(), message.Content); + return true; + } + UniqueId.TryParse(messageId, out UniqueId uid); + message.RichContent = BuildRichContentForEmail(emailMessage, uid.ToString()); + return true; + } + var emails = await _emailProvider.GetUnreadEmails(); + message.Content = "Please choose which one to read for you."; + message.RichContent = BuildRichContentForSubject(emails.OrderByDescending(x => x.CreateDate).ToList()); + return true; + } + catch (Exception ex) + { + var msg = $"Failed to read the emails. {ex.Message}"; + _logger.LogError($"{msg}\n(Error: {ex.Message})"); + message.Content = msg; + return false; + } + } + public RichContent BuildRichContentForSummary(string conversationId, string content, string editorType = EditorTypeEnum.Text) + { + return new RichContent() + { + FillPostback = true, + Editor = editorType, + Recipient = new Recipient() { Id = conversationId }, + Message = new ButtonTemplateMessage() + { + Text = content, + } + }; + } + private RichContent BuildRichContentForSubject(List emailSubjects) + { + var text = "Please let me know which message I need to read?"; + + return new RichContent + { + FillPostback = true, + Editor = EditorTypeEnum.None, + Recipient = new Recipient + { + Id = _state.GetConversationId() + }, + Message = new GenericTemplateMessage + { + Text = text, + Elements = GetElements(emailSubjects) + } + }; + } + private RichContent BuildRichContentForEmail(EmailModel email, string uid) + { + var text = "The email details are given below. \n"; + + return new RichContent + { + FillPostback = true, + Editor = EditorTypeEnum.None, + Recipient = new Recipient + { + Id = _state.GetConversationId() + }, + Message = new GenericTemplateMessage + { + Text = $"{text}From: {email.From.ToString()}\nSubject: {email.Subject}\n{email.Body}", + Elements = GetElements(uid) + } + }; + } + private static List GetElements(string uid) + { + var element = new EmailSubjectElement() + { + Buttons = new ElementButton[] + { + BuildMarkReadElementButton(uid) + } + }; + return new List() { element }; + } + private static List GetElements(List emails) + { + var elements = emails.Select(e => new EmailSubjectElement + { + Title = $"Subject: {e.Subject}", + Subtitle = $"From: {e.From}
Date: {e.CreateDate}", + Buttons = BuildElementButton(e) + }).ToList(); + return elements; + } + private static ElementButton[] BuildElementButton(EmailModel email) + { + var elements = new List() { }; + elements.Add(new ElementButton + { + Title = "Read", + Payload = $"{RICH_CONTENT_READ_EMAIL}: {email.UId}.", + Type = "text", + }); + elements.Add(new ElementButton + { + Title = "Summarize", + Payload = $"{RICH_CONTENT_SUMMARIZE}: {email.UId}.", + Type = "text", + }); + return elements.ToArray(); + } + private static ElementButton BuildMarkReadElementButton(string uId) + { + return new ElementButton + { + Title = "Mark as read", + Payload = $"{RICH_CONTENT_MARK_READ}: {uId}.", + Type = "text", + }; + } +} diff --git a/src/Plugins/BotSharp.Plugin.EmailHandler/Functions/HandleEmailRequestFn.cs b/src/Plugins/BotSharp.Plugin.EmailHandler/Functions/HandleEmailSenderFn.cs similarity index 93% rename from src/Plugins/BotSharp.Plugin.EmailHandler/Functions/HandleEmailRequestFn.cs rename to src/Plugins/BotSharp.Plugin.EmailHandler/Functions/HandleEmailSenderFn.cs index 9f8406a8b..45dc65beb 100644 --- a/src/Plugins/BotSharp.Plugin.EmailHandler/Functions/HandleEmailRequestFn.cs +++ b/src/Plugins/BotSharp.Plugin.EmailHandler/Functions/HandleEmailSenderFn.cs @@ -5,25 +5,25 @@ namespace BotSharp.Plugin.EmailHandler.Functions; -public class HandleEmailRequestFn : IFunctionCallback +public class HandleEmailSenderFn : IFunctionCallback { - public string Name => "handle_email_request"; - public string Indication => "Handling email request"; + public string Name => "handle_email_sender"; + public string Indication => "Handling email send request"; private readonly IServiceProvider _services; - private readonly ILogger _logger; + private readonly ILogger _logger; private readonly IHttpClientFactory _httpClientFactory; private readonly IHttpContextAccessor _context; private readonly BotSharpOptions _options; - private readonly EmailHandlerSettings _emailSettings; + private readonly EmailSenderSettings _emailSettings; - public HandleEmailRequestFn( + public HandleEmailSenderFn( IServiceProvider services, - ILogger logger, + ILogger logger, IHttpClientFactory httpClientFactory, IHttpContextAccessor context, BotSharpOptions options, - EmailHandlerSettings emailPluginSettings) + EmailSenderSettings emailPluginSettings) { _services = services; _logger = logger; diff --git a/src/Plugins/BotSharp.Plugin.EmailHandler/Hooks/EmailHandlerHook.cs b/src/Plugins/BotSharp.Plugin.EmailHandler/Hooks/EmailReaderHook.cs similarity index 90% rename from src/Plugins/BotSharp.Plugin.EmailHandler/Hooks/EmailHandlerHook.cs rename to src/Plugins/BotSharp.Plugin.EmailHandler/Hooks/EmailReaderHook.cs index 59d7baf99..222c27b91 100644 --- a/src/Plugins/BotSharp.Plugin.EmailHandler/Hooks/EmailHandlerHook.cs +++ b/src/Plugins/BotSharp.Plugin.EmailHandler/Hooks/EmailReaderHook.cs @@ -12,13 +12,13 @@ namespace BotSharp.Plugin.EmailHandler.Hooks; -public class EmailHandlerHook : AgentHookBase +public class EmailReaderHook : AgentHookBase { - private static string FUNCTION_NAME = "handle_email_request"; + private static string FUNCTION_NAME = "handle_email_reader"; public override string SelfId => string.Empty; - public EmailHandlerHook(IServiceProvider services, AgentSettings settings) + public EmailReaderHook(IServiceProvider services, AgentSettings settings) : base(services, settings) { } diff --git a/src/Plugins/BotSharp.Plugin.EmailHandler/Hooks/EmailSenderHook.cs b/src/Plugins/BotSharp.Plugin.EmailHandler/Hooks/EmailSenderHook.cs new file mode 100644 index 000000000..d4ae8c16a --- /dev/null +++ b/src/Plugins/BotSharp.Plugin.EmailHandler/Hooks/EmailSenderHook.cs @@ -0,0 +1,63 @@ +using BotSharp.Abstraction.Agents; +using BotSharp.Abstraction.Agents.Enums; +using BotSharp.Abstraction.Agents.Settings; +using BotSharp.Abstraction.Functions.Models; +using BotSharp.Abstraction.Repositories; +using BotSharp.Plugin.EmailHandler.Enums; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace BotSharp.Plugin.EmailHandler.Hooks; + +public class EmailSenderHook : AgentHookBase +{ + private static string FUNCTION_NAME = "handle_email_sender"; + + public override string SelfId => string.Empty; + + public EmailSenderHook(IServiceProvider services, AgentSettings settings) + : base(services, settings) + { + } + public override void OnAgentLoaded(Agent agent) + { + var conv = _services.GetRequiredService(); + var isConvMode = conv.IsConversationMode(); + var isEnabled = !agent.Utilities.IsNullOrEmpty() && agent.Utilities.Contains(UtilityName.EmailHandler); + + if (isConvMode && isEnabled) + { + var (prompt, fn) = GetPromptAndFunction(); + if (fn != null) + { + if (!string.IsNullOrWhiteSpace(prompt)) + { + agent.Instruction += $"\r\n\r\n{prompt}\r\n\r\n"; + } + + if (agent.Functions == null) + { + agent.Functions = new List { fn }; + } + else + { + agent.Functions.Add(fn); + } + } + } + + base.OnAgentLoaded(agent); + } + + private (string, FunctionDef?) GetPromptAndFunction() + { + var db = _services.GetRequiredService(); + var agent = db.GetAgent(BuiltInAgentId.UtilityAssistant); + var prompt = agent?.Templates?.FirstOrDefault(x => x.Name.IsEqualTo($"{FUNCTION_NAME}.fn"))?.Content ?? string.Empty; + var loadAttachmentFn = agent?.Functions?.FirstOrDefault(x => x.Name.IsEqualTo(FUNCTION_NAME)); + return (prompt, loadAttachmentFn); + } +} diff --git a/src/Plugins/BotSharp.Plugin.EmailHandler/LlmContexts/LlmContextReader.cs b/src/Plugins/BotSharp.Plugin.EmailHandler/LlmContexts/LlmContextReader.cs new file mode 100644 index 000000000..ed71203d8 --- /dev/null +++ b/src/Plugins/BotSharp.Plugin.EmailHandler/LlmContexts/LlmContextReader.cs @@ -0,0 +1,19 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Text.Json.Serialization; +using System.Threading.Tasks; + +namespace BotSharp.Plugin.EmailHandler.LlmContexts +{ + public class LlmContextReader + { + [JsonPropertyName("mark_as_read")] + public bool? IsMarkRead { get; set; } + [JsonPropertyName("message_id")] + public string? MessageId { get; set; } + [JsonPropertyName("is_email_summarize")] + public bool? IsSummarize { get; set; } + } +} diff --git a/src/Plugins/BotSharp.Plugin.EmailHandler/Models/EmailModel.cs b/src/Plugins/BotSharp.Plugin.EmailHandler/Models/EmailModel.cs new file mode 100644 index 000000000..9414febba --- /dev/null +++ b/src/Plugins/BotSharp.Plugin.EmailHandler/Models/EmailModel.cs @@ -0,0 +1,19 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace BotSharp.Plugin.EmailHandler.Models +{ + public class EmailModel + { + public DateTime CreateDate { get; set; } + public string Subject { get; set; } + public string UId { get; set; } + public string From { get; set; } + public string Body { get; set; } + public string TextBody { get; set; } + + } +} diff --git a/src/Plugins/BotSharp.Plugin.EmailHandler/Models/EmailSubjectElement.cs b/src/Plugins/BotSharp.Plugin.EmailHandler/Models/EmailSubjectElement.cs new file mode 100644 index 000000000..a1cd263d9 --- /dev/null +++ b/src/Plugins/BotSharp.Plugin.EmailHandler/Models/EmailSubjectElement.cs @@ -0,0 +1,14 @@ +using BotSharp.Abstraction.Messaging.Models.RichContent.Template; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace BotSharp.Plugin.EmailHandler.Models +{ + public class EmailSubjectElement : GenericElement + { + public string Subject { get; set; } + } +} diff --git a/src/Plugins/BotSharp.Plugin.EmailHandler/Providers/DefaultEmailReader.cs b/src/Plugins/BotSharp.Plugin.EmailHandler/Providers/DefaultEmailReader.cs new file mode 100644 index 000000000..27c702b64 --- /dev/null +++ b/src/Plugins/BotSharp.Plugin.EmailHandler/Providers/DefaultEmailReader.cs @@ -0,0 +1,102 @@ +using BotSharp.Plugin.EmailHandler.Models; +using MailKit; +using MailKit.Net.Imap; +using MailKit.Search; +using MailKit.Security; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Text.RegularExpressions; +using System.Threading.Tasks; + +namespace BotSharp.Plugin.EmailHandler.Providers +{ + public class DefaultEmailReader : IEmailReader + { + public EmailReaderSettings _emailReaderSettings; + public const int MAX_UNREAD_COUNT = 5; + public DefaultEmailReader(EmailReaderSettings emailReaderSettings) + { + _emailReaderSettings = emailReaderSettings; + } + public async Task GetImapClient() + { + var client = new ImapClient(); + await client.ConnectAsync(_emailReaderSettings.IMAPServer, _emailReaderSettings.IMAPPort, SecureSocketOptions.SslOnConnect); + await client.AuthenticateAsync(_emailReaderSettings.Username, _emailReaderSettings.Password); + return client; + } + public async Task> GetUnreadEmails() + { + var emails = new List(); + using var client = await GetImapClient(); + await client.Inbox.OpenAsync(FolderAccess.ReadOnly); + var query = SearchQuery.NotSeen; + var result = await client.Inbox.SearchAsync(query); + var uIds = result.TakeLast(MAX_UNREAD_COUNT); + foreach (var uid in uIds) + { + var inboxMsg = await client.Inbox.GetMessageAsync(uid); + emails.Add(new EmailModel() + { + Subject = inboxMsg.Subject, + CreateDate = inboxMsg.Date.UtcDateTime, + From = FormatEmailAddress(inboxMsg.From.ToString()), + UId = uid.ToString() + + }); + } + await client.DisconnectAsync(true); + return emails; + } + public string FormatEmailAddress(string emailAddress) + { + string pattern = "\"([^\"]+)\"\\s*<([^>]+)>"; + + var match = Regex.Match(emailAddress, pattern); + if (match.Success) + { + string name = match.Groups[1].Value; + string email = match.Groups[2].Value; + string result = $"{name} {email}"; + return result; + } + return emailAddress; + } + public async Task GetEmailById(string id) + { + + UniqueId.TryParse(id, out UniqueId uid); + using var client = await GetImapClient(); + await client.Inbox.OpenAsync(FolderAccess.ReadOnly); + var message = await client.Inbox.GetMessageAsync(uid); + return new EmailModel() + { + CreateDate = message.Date.UtcDateTime, + From = FormatEmailAddress(message.From.ToString()), + Subject = message.Subject, + UId = uid.ToString(), + Body = message.HtmlBody, + TextBody = message.TextBody + }; + } + + public async Task MarkEmailAsReadById(string id) + { + try + { + UniqueId.TryParse(id, out UniqueId uid); + using var client = await GetImapClient(); + await client.Inbox.OpenAsync(FolderAccess.ReadWrite); + await client.Inbox.AddFlagsAsync(uid, MessageFlags.Seen, true); + await client.DisconnectAsync(true); + return true; + } + catch (Exception ex) + { + return false; + } + } + } +} diff --git a/src/Plugins/BotSharp.Plugin.EmailHandler/Providers/IEmailReader.cs b/src/Plugins/BotSharp.Plugin.EmailHandler/Providers/IEmailReader.cs new file mode 100644 index 000000000..9df635c47 --- /dev/null +++ b/src/Plugins/BotSharp.Plugin.EmailHandler/Providers/IEmailReader.cs @@ -0,0 +1,16 @@ +using BotSharp.Plugin.EmailHandler.Models; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace BotSharp.Plugin.EmailHandler.Providers +{ + public interface IEmailReader + { + public Task> GetUnreadEmails(); + Task GetEmailById(string id); + Task MarkEmailAsReadById(string id); + } +} diff --git a/src/Plugins/BotSharp.Plugin.EmailHandler/Settings/EmailReaderSettings.cs b/src/Plugins/BotSharp.Plugin.EmailHandler/Settings/EmailReaderSettings.cs new file mode 100644 index 000000000..cc130fe29 --- /dev/null +++ b/src/Plugins/BotSharp.Plugin.EmailHandler/Settings/EmailReaderSettings.cs @@ -0,0 +1,15 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace BotSharp.Plugin.EmailHandler.Settings; + +public class EmailReaderSettings +{ + public string Username { get; set; } = string.Empty; + public string Password { get; set; } = string.Empty; + public string IMAPServer { get; set; } = string.Empty; + public int IMAPPort { get; set; } +} diff --git a/src/Plugins/BotSharp.Plugin.EmailHandler/Settings/EmailHandlerSettings.cs b/src/Plugins/BotSharp.Plugin.EmailHandler/Settings/EmailSenderSettings.cs similarity index 91% rename from src/Plugins/BotSharp.Plugin.EmailHandler/Settings/EmailHandlerSettings.cs rename to src/Plugins/BotSharp.Plugin.EmailHandler/Settings/EmailSenderSettings.cs index ae7636ab0..6859e0981 100644 --- a/src/Plugins/BotSharp.Plugin.EmailHandler/Settings/EmailHandlerSettings.cs +++ b/src/Plugins/BotSharp.Plugin.EmailHandler/Settings/EmailSenderSettings.cs @@ -1,6 +1,6 @@ namespace BotSharp.Plugin.EmailHandler.Settings; -public class EmailHandlerSettings +public class EmailSenderSettings { public string EmailAddress { get; set; } = string.Empty; public string Name { get; set; } = string.Empty; diff --git a/src/Plugins/BotSharp.Plugin.EmailHandler/data/agents/6745151e-6d46-4a02-8de4-1c4f21c7da95/functions/handle_email_reader.json b/src/Plugins/BotSharp.Plugin.EmailHandler/data/agents/6745151e-6d46-4a02-8de4-1c4f21c7da95/functions/handle_email_reader.json new file mode 100644 index 000000000..bcea2ac8e --- /dev/null +++ b/src/Plugins/BotSharp.Plugin.EmailHandler/data/agents/6745151e-6d46-4a02-8de4-1c4f21c7da95/functions/handle_email_reader.json @@ -0,0 +1,22 @@ +{ + "name": "handle_email_reader", + "description": "If the user wants to read messages from email inbox or user wants to mark an email message as read.If message id is provided, capture it but it is not required. Then call this function to read the email message or mark any message as read.", + "parameters": { + "type": "object", + "properties": { + "mark_as_read": { + "to_read": "boolean", + "description": "Mark the boolean as true if the user wants to mark the message as read." + }, + "is_email_summarize": { + "to_read": "boolean", + "description": "Mark the boolean as true only if the user explicitly mentions that they want to summarize the particular message." + }, + "message_Id": { + "type": "string", + "description": "The message id of a particular email message." + } + }, + "required": [ "mark_as_read", "is_email_summarize" ] + } +} \ No newline at end of file diff --git a/src/Plugins/BotSharp.Plugin.EmailHandler/data/agents/6745151e-6d46-4a02-8de4-1c4f21c7da95/functions/handle_email_request.json b/src/Plugins/BotSharp.Plugin.EmailHandler/data/agents/6745151e-6d46-4a02-8de4-1c4f21c7da95/functions/handle_email_sender.json similarity index 97% rename from src/Plugins/BotSharp.Plugin.EmailHandler/data/agents/6745151e-6d46-4a02-8de4-1c4f21c7da95/functions/handle_email_request.json rename to src/Plugins/BotSharp.Plugin.EmailHandler/data/agents/6745151e-6d46-4a02-8de4-1c4f21c7da95/functions/handle_email_sender.json index a8a79998c..730c45970 100644 --- a/src/Plugins/BotSharp.Plugin.EmailHandler/data/agents/6745151e-6d46-4a02-8de4-1c4f21c7da95/functions/handle_email_request.json +++ b/src/Plugins/BotSharp.Plugin.EmailHandler/data/agents/6745151e-6d46-4a02-8de4-1c4f21c7da95/functions/handle_email_sender.json @@ -1,5 +1,5 @@ { - "name": "handle_email_request", + "name": "handle_email_sender", "description": "If the user requests to send an email with or without attachments or files, you need to capture the email content and the recipient email address. If the user explicitly enter email subject use the same if not intelligently capture the email subject from the content. Then call this function to send out email.", "parameters": { "type": "object", diff --git a/src/Plugins/BotSharp.Plugin.EmailHandler/data/agents/6745151e-6d46-4a02-8de4-1c4f21c7da95/templates/handle_email_reader.fn.liquid b/src/Plugins/BotSharp.Plugin.EmailHandler/data/agents/6745151e-6d46-4a02-8de4-1c4f21c7da95/templates/handle_email_reader.fn.liquid new file mode 100644 index 000000000..0efb6229d --- /dev/null +++ b/src/Plugins/BotSharp.Plugin.EmailHandler/data/agents/6745151e-6d46-4a02-8de4-1c4f21c7da95/templates/handle_email_reader.fn.liquid @@ -0,0 +1 @@ +Please call handle_email_reader if user wants to read messages from email inbox. \ No newline at end of file diff --git a/src/Plugins/BotSharp.Plugin.EmailHandler/data/agents/6745151e-6d46-4a02-8de4-1c4f21c7da95/templates/handle_email_request.fn.liquid b/src/Plugins/BotSharp.Plugin.EmailHandler/data/agents/6745151e-6d46-4a02-8de4-1c4f21c7da95/templates/handle_email_request.fn.liquid deleted file mode 100644 index 9091f6bf3..000000000 --- a/src/Plugins/BotSharp.Plugin.EmailHandler/data/agents/6745151e-6d46-4a02-8de4-1c4f21c7da95/templates/handle_email_request.fn.liquid +++ /dev/null @@ -1,2 +0,0 @@ -Please call handle_email_request if user wants to send email. -** Please take a look at the conversation and decide whether user wants to send email with files/attachments/images or not. \ No newline at end of file diff --git a/src/Plugins/BotSharp.Plugin.EmailHandler/data/agents/6745151e-6d46-4a02-8de4-1c4f21c7da95/templates/handle_email_sender.fn.liquid b/src/Plugins/BotSharp.Plugin.EmailHandler/data/agents/6745151e-6d46-4a02-8de4-1c4f21c7da95/templates/handle_email_sender.fn.liquid new file mode 100644 index 000000000..647942c6a --- /dev/null +++ b/src/Plugins/BotSharp.Plugin.EmailHandler/data/agents/6745151e-6d46-4a02-8de4-1c4f21c7da95/templates/handle_email_sender.fn.liquid @@ -0,0 +1,2 @@ +Please call handle_email_sender if user wants to send email. +** Please take a look at the conversation and decide whether user wants to send email with files/attachments/images or not.