diff options
author | x-yl <kylepereira@mail.com> | 2021-06-02 18:40:41 +0400 |
---|---|---|
committer | Ali Mohammad Pur <Ali.mpfard@gmail.com> | 2021-06-11 23:58:28 +0430 |
commit | 076c708d0a970c121d193770fac05f8798d59225 (patch) | |
tree | 48e460178db8d138c19bf94a7c85d69ca1b8e4ed /Userland/Libraries/LibIMAP/Client.cpp | |
parent | a6339297eccf3f9d0d81f7f12746add081b6cd31 (diff) | |
download | serenity-076c708d0a970c121d193770fac05f8798d59225.zip |
LibIMAP: Support for STORE and STATUS
Diffstat (limited to 'Userland/Libraries/LibIMAP/Client.cpp')
-rw-r--r-- | Userland/Libraries/LibIMAP/Client.cpp | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/Userland/Libraries/LibIMAP/Client.cpp b/Userland/Libraries/LibIMAP/Client.cpp index 21d623ec35..a0d79412b4 100644 --- a/Userland/Libraries/LibIMAP/Client.cpp +++ b/Userland/Libraries/LibIMAP/Client.cpp @@ -126,12 +126,18 @@ static ReadonlyBytes command_byte_buffer(CommandType command) return "SELECT"sv.bytes(); case CommandType::Fetch: return "FETCH"sv.bytes(); + case CommandType::Store: + return "STORE"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::UIDSearch: return "UID SEARCH"sv.bytes(); + case CommandType::Status: + return "STATUS"sv.bytes(); } VERIFY_NOT_REACHED(); } @@ -248,6 +254,32 @@ void Client::send_next_command() send_raw(buffer); m_expecting_response = true; } +RefPtr<Promise<Optional<SolidResponse>>> Client::store(StoreMethod method, Sequence sequence_set, bool silent, Vector<String> const& flags, bool uid) +{ + StringBuilder data_item_name; + switch (method) { + case StoreMethod::Replace: + data_item_name.append("FLAGS"); + break; + case StoreMethod::Add: + data_item_name.append("+FLAGS"); + break; + case StoreMethod::Remove: + data_item_name.append("-FLAGS"); + break; + } + if (silent) { + data_item_name.append(".SILENT"); + } + + StringBuilder flags_builder; + flags_builder.append('('); + flags_builder.join(" ", flags); + flags_builder.append(')'); + + auto command = Command { uid ? CommandType::UIDStore : CommandType::Store, m_current_command, { sequence_set.serialize(), data_item_name.build(), flags_builder.build() } }; + return cast_promise<SolidResponse>(send_command(move(command))); +} RefPtr<Promise<Optional<SolidResponse>>> Client::search(Optional<String> charset, Vector<SearchKey>&& keys, bool uid) { Vector<String> args; @@ -276,6 +308,36 @@ RefPtr<Promise<Optional<SolidResponse>>> Client::finish_idle() return cast_promise<SolidResponse>(promise); } +RefPtr<Promise<Optional<SolidResponse>>> Client::status(StringView mailbox, Vector<StatusItemType> const& types) +{ + Vector<String> args; + for (auto type : types) { + switch (type) { + case StatusItemType::Recent: + args.append("RECENT"); + break; + case StatusItemType::UIDNext: + args.append("UIDNEXT"); + break; + case StatusItemType::UIDValidity: + args.append("UIDVALIDITY"); + break; + case StatusItemType::Unseen: + args.append("UNSEEN"); + break; + case StatusItemType::Messages: + args.append("MESSAGES"); + break; + } + } + StringBuilder types_list; + types_list.append('('); + types_list.join(" ", args); + types_list.append(')'); + auto command = Command { CommandType::Status, m_current_command, { mailbox, types_list.build() } }; + return cast_promise<SolidResponse>(send_command(move(command))); +} + void Client::close() { if (m_tls) { |