mirror of
https://github.com/RGBCube/serenity
synced 2025-07-27 15:27:35 +00:00
SpiceAgent: Implement FileTransferStatus
messages
This commit is contained in:
parent
476774d681
commit
af91c75080
3 changed files with 115 additions and 0 deletions
|
@ -241,4 +241,30 @@ ErrorOr<String> FileTransferStartMessage::debug_description()
|
||||||
return builder.to_string();
|
return builder.to_string();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ErrorOr<FileTransferStatusMessage> FileTransferStatusMessage::read_from_stream(AK::Stream& stream)
|
||||||
|
{
|
||||||
|
auto id = TRY(stream.read_value<u32>());
|
||||||
|
auto status = TRY(stream.read_value<FileTransferStatus>());
|
||||||
|
|
||||||
|
return FileTransferStatusMessage(id, status);
|
||||||
|
}
|
||||||
|
|
||||||
|
ErrorOr<void> FileTransferStatusMessage::write_to_stream(AK::Stream& stream)
|
||||||
|
{
|
||||||
|
TRY(stream.write_value(id()));
|
||||||
|
TRY(stream.write_value(status()));
|
||||||
|
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
|
||||||
|
ErrorOr<String> FileTransferStatusMessage::debug_description()
|
||||||
|
{
|
||||||
|
StringBuilder builder;
|
||||||
|
TRY(builder.try_append("FileTransferStatus { "sv));
|
||||||
|
TRY(builder.try_appendff("id = {}, ", id()));
|
||||||
|
TRY(builder.try_appendff("status = {}", status()));
|
||||||
|
TRY(builder.try_append(" }"sv));
|
||||||
|
return builder.to_string();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -55,6 +55,19 @@ ErrorOr<String> clipboard_data_type_to_mime_type(ClipboardDataType type);
|
||||||
ErrorOr<ClipboardDataType> clipboard_data_type_from_raw_value(u32 value);
|
ErrorOr<ClipboardDataType> clipboard_data_type_from_raw_value(u32 value);
|
||||||
ErrorOr<ClipboardDataType> clipboard_data_type_from_mime_type(String const& mime_type);
|
ErrorOr<ClipboardDataType> clipboard_data_type_from_mime_type(String const& mime_type);
|
||||||
|
|
||||||
|
// Used to describe what state the current file transfer is in
|
||||||
|
enum class FileTransferStatus : u32 {
|
||||||
|
CanSendData = 0,
|
||||||
|
Cancelled,
|
||||||
|
Error,
|
||||||
|
Success,
|
||||||
|
NotEnoughSpace,
|
||||||
|
SessionLocked,
|
||||||
|
AgentNotConnected,
|
||||||
|
Disabled,
|
||||||
|
__End
|
||||||
|
};
|
||||||
|
|
||||||
class Message {
|
class Message {
|
||||||
public:
|
public:
|
||||||
// The spice protocol headers contain a bit of documentation about these, but nothing major:
|
// The spice protocol headers contain a bit of documentation about these, but nothing major:
|
||||||
|
@ -206,6 +219,29 @@ private:
|
||||||
Metadata m_metadata;
|
Metadata m_metadata;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Sent/recieved to indicate the status of the current file transfer.
|
||||||
|
class FileTransferStatusMessage : public Message {
|
||||||
|
public:
|
||||||
|
FileTransferStatusMessage(u32 id, FileTransferStatus status)
|
||||||
|
: Message(Type::FileTransferStatus)
|
||||||
|
, m_id(id)
|
||||||
|
, m_status(status)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
static ErrorOr<FileTransferStatusMessage> read_from_stream(AK::Stream& stream);
|
||||||
|
|
||||||
|
ErrorOr<void> write_to_stream(AK::Stream& stream);
|
||||||
|
ErrorOr<String> debug_description() override;
|
||||||
|
|
||||||
|
u32 id() const { return m_id; }
|
||||||
|
FileTransferStatus const& status() { return m_status; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
u32 m_id { 0 };
|
||||||
|
FileTransferStatus m_status;
|
||||||
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace AK {
|
namespace AK {
|
||||||
|
@ -246,4 +282,50 @@ struct Formatter<SpiceAgent::ClipboardDataType> : Formatter<StringView> {
|
||||||
return Formatter<StringView>::format(builder, string);
|
return Formatter<StringView>::format(builder, string);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
template<>
|
||||||
|
struct Formatter<SpiceAgent::FileTransferStatus> : Formatter<StringView> {
|
||||||
|
ErrorOr<void> format(FormatBuilder& builder, SpiceAgent::FileTransferStatus const& header)
|
||||||
|
{
|
||||||
|
auto string = "Unknown"sv;
|
||||||
|
switch (header) {
|
||||||
|
case SpiceAgent::FileTransferStatus::AgentNotConnected:
|
||||||
|
string = "AgentNotConnected"sv;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SpiceAgent::FileTransferStatus::Cancelled:
|
||||||
|
string = "Cancelled"sv;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SpiceAgent::FileTransferStatus::CanSendData:
|
||||||
|
string = "CanSendData"sv;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SpiceAgent::FileTransferStatus::Disabled:
|
||||||
|
string = "Disabled"sv;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SpiceAgent::FileTransferStatus::Error:
|
||||||
|
string = "Error"sv;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SpiceAgent::FileTransferStatus::NotEnoughSpace:
|
||||||
|
string = "NotEnoughSpace"sv;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SpiceAgent::FileTransferStatus::SessionLocked:
|
||||||
|
string = "SessionLocked"sv;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SpiceAgent::FileTransferStatus::Success:
|
||||||
|
string = "Success"sv;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return Formatter<StringView>::format(builder, string);
|
||||||
|
}
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -154,6 +154,13 @@ ErrorOr<void> SpiceAgent::on_message_received()
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
case Message::Type::FileTransferStatus: {
|
||||||
|
auto message = TRY(FileTransferStatusMessage::read_from_stream(stream));
|
||||||
|
dbgln("File transfer {} has been cancelled: {}", message.id(), message.status());
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case Message::Type::FileTransferStart: {
|
case Message::Type::FileTransferStart: {
|
||||||
auto message = TRY(FileTransferStartMessage::read_from_stream(stream));
|
auto message = TRY(FileTransferStartMessage::read_from_stream(stream));
|
||||||
dbgln("File transfer request received: {}", TRY(message.debug_description()));
|
dbgln("File transfer request received: {}", TRY(message.debug_description()));
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue