diff --git a/Userland/Libraries/LibIMAP/Client.cpp b/Userland/Libraries/LibIMAP/Client.cpp index a0d79412b4..b5543d881a 100644 --- a/Userland/Libraries/LibIMAP/Client.cpp +++ b/Userland/Libraries/LibIMAP/Client.cpp @@ -128,14 +128,24 @@ static ReadonlyBytes command_byte_buffer(CommandType command) return "FETCH"sv.bytes(); case CommandType::Store: return "STORE"sv.bytes(); + case CommandType::Copy: + return "COPY"sv.bytes(); + case CommandType::Create: + return "CREATE"sv.bytes(); + case CommandType::Delete: + return "DELETE"sv.bytes(); case CommandType::Search: return "SEARCH"sv.bytes(); case CommandType::UIDFetch: return "UID FETCH"sv.bytes(); case CommandType::UIDStore: return "UID STORE"sv.bytes(); + case CommandType::UIDCopy: + return "UID COPY"sv.bytes(); case CommandType::UIDSearch: return "UID SEARCH"sv.bytes(); + case CommandType::Rename: + return "RENAME"sv.bytes(); case CommandType::Status: return "STATUS"sv.bytes(); } @@ -254,6 +264,18 @@ void Client::send_next_command() send_raw(buffer); m_expecting_response = true; } +RefPtr>> Client::create_mailbox(StringView name) +{ + auto command = Command { CommandType::Create, m_current_command, { name } }; + return cast_promise(send_command(move(command))); +} + +RefPtr>> Client::delete_mailbox(StringView name) +{ + auto command = Command { CommandType::Delete, m_current_command, { name } }; + return cast_promise(send_command(move(command))); +} + RefPtr>> Client::store(StoreMethod method, Sequence sequence_set, bool silent, Vector const& flags, bool uid) { StringBuilder data_item_name; @@ -338,6 +360,19 @@ RefPtr>> Client::status(StringView mailbox, Vect return cast_promise(send_command(move(command))); } +RefPtr>> Client::rename(StringView from, StringView to) +{ + auto command = Command { CommandType::Rename, m_current_command, { from, to } }; + return cast_promise(send_command(move(command))); +} +RefPtr>> Client::copy(Sequence sequence_set, StringView name, bool uid) +{ + auto command = Command { + uid ? CommandType::UIDCopy : CommandType::Copy, m_current_command, { sequence_set.serialize(), name } + }; + + return cast_promise(send_command(move(command))); +} void Client::close() { if (m_tls) { diff --git a/Userland/Libraries/LibIMAP/Client.h b/Userland/Libraries/LibIMAP/Client.h index f6329547d8..2e79d7eb13 100644 --- a/Userland/Libraries/LibIMAP/Client.h +++ b/Userland/Libraries/LibIMAP/Client.h @@ -27,6 +27,10 @@ public: RefPtr>> search(Optional charset, Vector&& search_keys, bool uid); RefPtr>> fetch(FetchCommand request, bool uid); RefPtr>> store(StoreMethod, Sequence, bool silent, Vector const& flags, bool uid); + RefPtr>> copy(Sequence sequence_set, StringView name, bool uid); + RefPtr>> create_mailbox(StringView name); + RefPtr>> delete_mailbox(StringView name); + RefPtr>> rename(StringView from, StringView to); RefPtr>> idle(); RefPtr>> finish_idle(); RefPtr>> status(StringView mailbox, Vector const& types); diff --git a/Userland/Libraries/LibIMAP/Objects.h b/Userland/Libraries/LibIMAP/Objects.h index 76f2da186a..3ad9b51bed 100644 --- a/Userland/Libraries/LibIMAP/Objects.h +++ b/Userland/Libraries/LibIMAP/Objects.h @@ -18,16 +18,21 @@ namespace IMAP { enum class CommandType { Capability, + Copy, + Create, + Delete, Fetch, Idle, List, Login, Logout, Noop, + Rename, Search, Select, Status, Store, + UIDCopy, UIDFetch, UIDSearch, UIDStore,