diff mbox series

[v1] obex: Implement support for message listing format version 1.1 for MCE

Message ID 20241220125812.84592-1-quic_amisjain@quicinc.com
State Superseded
Headers show
Series [v1] obex: Implement support for message listing format version 1.1 for MCE | expand

Commit Message

Amisha Jain Dec. 20, 2024, 12:58 p.m. UTC
As per spec, Messages-Listing Format Version 1.1 is being marked
mandatory feature to be supported in MAP 1.3 & above versions.
This change is added for MAP client role.

This change is required for passing below testcases-
1) MAP/MCE/MFB/BV-01-C
Verify that the MCE correctly advertises the correct feature bits
in the MNS SDP record.
2) MAP/MCE/MFB/BV-03-C
Verify that the MCE correctly advertises the correct MapSupportedFeatures
bits in the MNS SDP record during MAS connection.

Also add the Messages-Listing Format Version 1.1 as supported
in mns sdp record.

---
 obexd/client/map.c | 169 +++++++++++++++++++++++++++++++++++++++++++++
 src/profile.c      |   2 +-
 2 files changed, 170 insertions(+), 1 deletion(-)

Comments

Amisha Jain Dec. 23, 2024, 9:36 a.m. UTC | #1
Hi Luiz,

> -----Original Message-----
> From: Luiz Augusto von Dentz <luiz.dentz@gmail.com>
> Sent: Friday, December 20, 2024 8:17 PM
> To: Amisha Jain (QUIC) <quic_amisjain@quicinc.com>
> Cc: linux-bluetooth@vger.kernel.org; Mohammed Sameer Mulla (QUIC)
> <quic_mohamull@quicinc.com>; Harish Bandi (QUIC)
> <quic_hbandi@quicinc.com>; Anubhav Gupta (QUIC)
> <quic_anubhavg@quicinc.com>
> Subject: Re: [PATCH v1] obex: Implement support for message listing format
> version 1.1 for MCE
> 
> Hi Amisha,
> 
> On Fri, Dec 20, 2024 at 7:58 AM Amisha Jain <quic_amisjain@quicinc.com>
> wrote:
> >
> > As per spec, Messages-Listing Format Version 1.1 is being marked
> > mandatory feature to be supported in MAP 1.3 & above versions.
> > This change is added for MAP client role.
> >
> > This change is required for passing below testcases-
> > 1) MAP/MCE/MFB/BV-01-C
> > Verify that the MCE correctly advertises the correct feature bits in
> > the MNS SDP record.
> > 2) MAP/MCE/MFB/BV-03-C
> > Verify that the MCE correctly advertises the correct
> > MapSupportedFeatures bits in the MNS SDP record during MAS connection.
> >
> > Also add the Messages-Listing Format Version 1.1 as supported in mns
> > sdp record.
> >
> > ---
> >  obexd/client/map.c | 169
> +++++++++++++++++++++++++++++++++++++++++++++
> >  src/profile.c      |   2 +-
> >  2 files changed, 170 insertions(+), 1 deletion(-)
> >
> > diff --git a/obexd/client/map.c b/obexd/client/map.c index
> > 29b0ed96e..c6f3dd342 100644
> > --- a/obexd/client/map.c
> > +++ b/obexd/client/map.c
> > @@ -123,6 +123,11 @@ struct map_msg {
> >         uint64_t attachment_size;
> >         uint8_t flags;
> >         char *folder;
> > +       char *delivery_status;
> > +       uint64_t conversation_id;
> > +       char *conversation_name;
> > +       char *direction;
> > +       char *attachment_mime_types;
> >         GDBusPendingPropertySet pending;  };
> >
> > @@ -418,6 +423,10 @@ static void map_msg_free(void *data)
> >         g_free(msg->recipient_address);
> >         g_free(msg->type);
> >         g_free(msg->status);
> > +       g_free(msg->delivery_status);
> > +       g_free(msg->conversation_name);
> > +       g_free(msg->direction);
> > +       g_free(msg->attachment_mime_types);
> >         g_free(msg);
> >  }
> >
> > @@ -778,6 +787,93 @@ static void set_deleted(const GDBusPropertyTable
> *property,
> >         set_status(property, iter, id, STATUS_DELETE, data);  }
> >
> > +static gboolean delivery_status_exists(const GDBusPropertyTable
> *property,
> > +                                                               void
> > +*data) {
> > +       struct map_msg *msg = data;
> > +
> > +       return msg->delivery_status != NULL; }
> > +
> > +static gboolean get_delivery_status(const GDBusPropertyTable *property,
> > +                                       DBusMessageIter *iter, void
> > +*data) {
> > +       struct map_msg *msg = data;
> > +
> > +       dbus_message_iter_append_basic(iter, DBUS_TYPE_STRING,
> > +
> > + &msg->delivery_status);
> > +
> > +       return TRUE;
> > +}
> > +
> > +static gboolean get_conversation_id(const GDBusPropertyTable *property,
> > +                                       DBusMessageIter *iter, void
> > +*data) {
> > +       struct map_msg *msg = data;
> > +
> > +       dbus_message_iter_append_basic(iter, DBUS_TYPE_UINT64,
> > +
> > + &msg->conversation_id);
> > +
> > +       return TRUE;
> > +}
> > +
> > +static gboolean conversation_name_exists(const GDBusPropertyTable
> *property,
> > +                                                               void
> > +*data) {
> > +       struct map_msg *msg = data;
> > +
> > +       return msg->conversation_name != NULL; }
> > +
> > +static gboolean get_conversation_name(const GDBusPropertyTable
> *property,
> > +                                       DBusMessageIter *iter, void
> > +*data) {
> > +       struct map_msg *msg = data;
> > +
> > +       dbus_message_iter_append_basic(iter, DBUS_TYPE_STRING,
> > +
> > + &msg->conversation_name);
> > +
> > +       return TRUE;
> > +}
> > +
> > +static gboolean direction_exists(const GDBusPropertyTable *property,
> > +                                                               void
> > +*data) {
> > +       struct map_msg *msg = data;
> > +
> > +       return msg->direction != NULL; }
> > +
> > +static gboolean get_direction(const GDBusPropertyTable *property,
> > +                                       DBusMessageIter *iter, void
> > +*data) {
> > +       struct map_msg *msg = data;
> > +
> > +       dbus_message_iter_append_basic(iter, DBUS_TYPE_STRING,
> > +
> > + &msg->direction);
> > +
> > +       return TRUE;
> > +}
> > +
> > +static gboolean attachment_mime_exists(const GDBusPropertyTable
> *property,
> > +                                                               void
> > +*data) {
> > +       struct map_msg *msg = data;
> > +
> > +       return msg->attachment_mime_types != NULL; }
> > +
> > +static gboolean get_attachment_mime_types(const GDBusPropertyTable
> *property,
> > +                                       DBusMessageIter *iter, void
> > +*data) {
> > +       struct map_msg *msg = data;
> > +
> > +       dbus_message_iter_append_basic(iter, DBUS_TYPE_STRING,
> > +
> > + &msg->attachment_mime_types);
> > +
> > +       return TRUE;
> > +}
> > +
> >  static const GDBusMethodTable map_msg_methods[] = {
> >         { GDBUS_METHOD("Get",
> >                         GDBUS_ARGS({ "targetfile", "s" }, @@ -809,6
> > +905,13 @@ static const GDBusPropertyTable map_msg_properties[] = {
> >         { "Sent", "b", get_sent },
> >         { "Protected", "b", get_protected },
> >         { "Deleted", "b", NULL, set_deleted },
> > +       { "DeliveryStatus", "s", get_delivery_status, NULL,
> delivery_status_exists },
> > +       { "ConversationId", "t", get_conversation_id },
> > +       { "ConversationName", "s", get_conversation_name, NULL,
> > +                                               conversation_name_exists },
> > +       { "Direction", "s", get_direction, NULL, direction_exists },
> > +       { "AttachmentMimeTypes", "s", get_attachment_mime_types, NULL,
> > +
> > + attachment_mime_exists },
> 
> Before you go ahead adding new properties you need to update
> org.bluez.obex.Message interface explaining what each new property
> represents, if they are optional, etc.
> 

I have updated org.bluez.obex.Message.rst in separate patch.

> >         { }
> >  };
> >
> > @@ -1061,6 +1164,67 @@ static void parse_protected(struct map_msg
> *msg, const char *value)
> >                                                 MAP_MSG_INTERFACE,
> > "Protected");  }
> >
> > +static void parse_delivery_status(struct map_msg *msg, const char
> > +*value) {
> > +       if (g_strcmp0(msg->delivery_status, value) == 0)
> > +               return;
> > +
> > +       g_free(msg->delivery_status);
> > +       msg->delivery_status = g_strdup(value);
> > +
> > +       g_dbus_emit_property_changed(conn, msg->path,
> > +                                       MAP_MSG_INTERFACE,
> > +"DeliveryStatus"); }
> > +
> > +static void parse_conversation_id(struct map_msg *msg, const char
> > +*value) {
> > +       uint64_t conversation_id = strtoull(value, NULL, 16);
> > +
> > +       if (msg->conversation_id == conversation_id)
> > +               return;
> > +
> > +       msg->conversation_id = conversation_id;
> > +
> > +       g_dbus_emit_property_changed(conn, msg->path,
> > +                                       MAP_MSG_INTERFACE,
> > +"ConversationId"); }
> > +
> > +static void parse_conversation_name(struct map_msg *msg, const char
> > +*value) {
> > +       if (g_strcmp0(msg->conversation_name, value) == 0)
> > +               return;
> > +
> > +       g_free(msg->conversation_name);
> > +       msg->conversation_name = g_strdup(value);
> > +
> > +       g_dbus_emit_property_changed(conn, msg->path,
> > +                                               MAP_MSG_INTERFACE,
> > +"ConversationName"); }
> > +
> > +static void parse_direction(struct map_msg *msg, const char *value) {
> > +       if (g_strcmp0(msg->direction, value) == 0)
> > +               return;
> > +
> > +       g_free(msg->direction);
> > +       msg->direction = g_strdup(value);
> > +
> > +       g_dbus_emit_property_changed(conn, msg->path,
> > +                                               MAP_MSG_INTERFACE,
> > +"Direction"); }
> > +
> > +static void parse_mime_types(struct map_msg *msg, const char *value)
> > +{
> > +       if (g_strcmp0(msg->attachment_mime_types, value) == 0)
> > +               return;
> > +
> > +       g_free(msg->attachment_mime_types);
> > +       msg->attachment_mime_types = g_strdup(value);
> > +
> > +       g_dbus_emit_property_changed(conn, msg->path,
> > +                                               MAP_MSG_INTERFACE,
> > +"AttachmentMimeTypes"); }
> > +
> >  static const struct map_msg_parser {
> >         const char *name;
> >         void (*func) (struct map_msg *msg, const char *value); @@
> > -1081,6 +1245,11 @@ static const struct map_msg_parser {
> >                 { "read", parse_read },
> >                 { "sent", parse_sent },
> >                 { "protected", parse_protected },
> > +               { "delivery_status", parse_delivery_status},
> > +               { "conversation_id", parse_conversation_id},
> > +               { "conversation_name", parse_conversation_name},
> > +               { "direction", parse_direction},
> > +               { "attachment_mime_types", parse_mime_types},
> >                 { }
> >  };
> >
> > diff --git a/src/profile.c b/src/profile.c index 6bc6778de..70ac058f4
> > 100644
> > --- a/src/profile.c
> > +++ b/src/profile.c
> > @@ -563,7 +563,7 @@
> >                         <text value=\"%s\"/>                            \
> >                 </attribute>                                            \
> >                 <attribute id=\"0x0317\">                               \
> > -                       <uint32 value=\"0x0000007f\"/>                  \
> > +                       <uint32 value=\"0x0000027f\"/>                  \
> >                 </attribute>                                            \
> >                 <attribute id=\"0x0200\">                               \
> >                         <uint16 value=\"%u\" name=\"psm\"/>             \
> 
> Are you bumping the version here? I guess we want to update the
> documentation about the profiles versions as well.
> 

No, I am not bumping version here.
This is to update the ' MapSupportedFeatures' attribute in MNS SDP record to add support for 
Messages-Listing Format Version 1.1.

> > --
> > 2.34.1
> >
> >
> 
> 
> --
> Luiz Augusto von Dentz

Thanks,
Amisha
diff mbox series

Patch

diff --git a/obexd/client/map.c b/obexd/client/map.c
index 29b0ed96e..c6f3dd342 100644
--- a/obexd/client/map.c
+++ b/obexd/client/map.c
@@ -123,6 +123,11 @@  struct map_msg {
 	uint64_t attachment_size;
 	uint8_t flags;
 	char *folder;
+	char *delivery_status;
+	uint64_t conversation_id;
+	char *conversation_name;
+	char *direction;
+	char *attachment_mime_types;
 	GDBusPendingPropertySet pending;
 };
 
@@ -418,6 +423,10 @@  static void map_msg_free(void *data)
 	g_free(msg->recipient_address);
 	g_free(msg->type);
 	g_free(msg->status);
+	g_free(msg->delivery_status);
+	g_free(msg->conversation_name);
+	g_free(msg->direction);
+	g_free(msg->attachment_mime_types);
 	g_free(msg);
 }
 
@@ -778,6 +787,93 @@  static void set_deleted(const GDBusPropertyTable *property,
 	set_status(property, iter, id, STATUS_DELETE, data);
 }
 
+static gboolean delivery_status_exists(const GDBusPropertyTable *property,
+								void *data)
+{
+	struct map_msg *msg = data;
+
+	return msg->delivery_status != NULL;
+}
+
+static gboolean get_delivery_status(const GDBusPropertyTable *property,
+					DBusMessageIter *iter, void *data)
+{
+	struct map_msg *msg = data;
+
+	dbus_message_iter_append_basic(iter, DBUS_TYPE_STRING,
+						&msg->delivery_status);
+
+	return TRUE;
+}
+
+static gboolean get_conversation_id(const GDBusPropertyTable *property,
+					DBusMessageIter *iter, void *data)
+{
+	struct map_msg *msg = data;
+
+	dbus_message_iter_append_basic(iter, DBUS_TYPE_UINT64,
+						&msg->conversation_id);
+
+	return TRUE;
+}
+
+static gboolean conversation_name_exists(const GDBusPropertyTable *property,
+								void *data)
+{
+	struct map_msg *msg = data;
+
+	return msg->conversation_name != NULL;
+}
+
+static gboolean get_conversation_name(const GDBusPropertyTable *property,
+					DBusMessageIter *iter, void *data)
+{
+	struct map_msg *msg = data;
+
+	dbus_message_iter_append_basic(iter, DBUS_TYPE_STRING,
+						&msg->conversation_name);
+
+	return TRUE;
+}
+
+static gboolean direction_exists(const GDBusPropertyTable *property,
+								void *data)
+{
+	struct map_msg *msg = data;
+
+	return msg->direction != NULL;
+}
+
+static gboolean get_direction(const GDBusPropertyTable *property,
+					DBusMessageIter *iter, void *data)
+{
+	struct map_msg *msg = data;
+
+	dbus_message_iter_append_basic(iter, DBUS_TYPE_STRING,
+							&msg->direction);
+
+	return TRUE;
+}
+
+static gboolean attachment_mime_exists(const GDBusPropertyTable *property,
+								void *data)
+{
+	struct map_msg *msg = data;
+
+	return msg->attachment_mime_types != NULL;
+}
+
+static gboolean get_attachment_mime_types(const GDBusPropertyTable *property,
+					DBusMessageIter *iter, void *data)
+{
+	struct map_msg *msg = data;
+
+	dbus_message_iter_append_basic(iter, DBUS_TYPE_STRING,
+						&msg->attachment_mime_types);
+
+	return TRUE;
+}
+
 static const GDBusMethodTable map_msg_methods[] = {
 	{ GDBUS_METHOD("Get",
 			GDBUS_ARGS({ "targetfile", "s" },
@@ -809,6 +905,13 @@  static const GDBusPropertyTable map_msg_properties[] = {
 	{ "Sent", "b", get_sent },
 	{ "Protected", "b", get_protected },
 	{ "Deleted", "b", NULL, set_deleted },
+	{ "DeliveryStatus", "s", get_delivery_status, NULL, delivery_status_exists },
+	{ "ConversationId", "t", get_conversation_id },
+	{ "ConversationName", "s", get_conversation_name, NULL,
+						conversation_name_exists },
+	{ "Direction", "s", get_direction, NULL, direction_exists },
+	{ "AttachmentMimeTypes", "s", get_attachment_mime_types, NULL,
+							attachment_mime_exists },
 	{ }
 };
 
@@ -1061,6 +1164,67 @@  static void parse_protected(struct map_msg *msg, const char *value)
 						MAP_MSG_INTERFACE, "Protected");
 }
 
+static void parse_delivery_status(struct map_msg *msg, const char *value)
+{
+	if (g_strcmp0(msg->delivery_status, value) == 0)
+		return;
+
+	g_free(msg->delivery_status);
+	msg->delivery_status = g_strdup(value);
+
+	g_dbus_emit_property_changed(conn, msg->path,
+					MAP_MSG_INTERFACE, "DeliveryStatus");
+}
+
+static void parse_conversation_id(struct map_msg *msg, const char *value)
+{
+	uint64_t conversation_id = strtoull(value, NULL, 16);
+
+	if (msg->conversation_id == conversation_id)
+		return;
+
+	msg->conversation_id = conversation_id;
+
+	g_dbus_emit_property_changed(conn, msg->path,
+					MAP_MSG_INTERFACE, "ConversationId");
+}
+
+static void parse_conversation_name(struct map_msg *msg, const char *value)
+{
+	if (g_strcmp0(msg->conversation_name, value) == 0)
+		return;
+
+	g_free(msg->conversation_name);
+	msg->conversation_name = g_strdup(value);
+
+	g_dbus_emit_property_changed(conn, msg->path,
+						MAP_MSG_INTERFACE, "ConversationName");
+}
+
+static void parse_direction(struct map_msg *msg, const char *value)
+{
+	if (g_strcmp0(msg->direction, value) == 0)
+		return;
+
+	g_free(msg->direction);
+	msg->direction = g_strdup(value);
+
+	g_dbus_emit_property_changed(conn, msg->path,
+						MAP_MSG_INTERFACE, "Direction");
+}
+
+static void parse_mime_types(struct map_msg *msg, const char *value)
+{
+	if (g_strcmp0(msg->attachment_mime_types, value) == 0)
+		return;
+
+	g_free(msg->attachment_mime_types);
+	msg->attachment_mime_types = g_strdup(value);
+
+	g_dbus_emit_property_changed(conn, msg->path,
+						MAP_MSG_INTERFACE, "AttachmentMimeTypes");
+}
+
 static const struct map_msg_parser {
 	const char *name;
 	void (*func) (struct map_msg *msg, const char *value);
@@ -1081,6 +1245,11 @@  static const struct map_msg_parser {
 		{ "read", parse_read },
 		{ "sent", parse_sent },
 		{ "protected", parse_protected },
+		{ "delivery_status", parse_delivery_status},
+		{ "conversation_id", parse_conversation_id},
+		{ "conversation_name", parse_conversation_name},
+		{ "direction", parse_direction},
+		{ "attachment_mime_types", parse_mime_types},
 		{ }
 };
 
diff --git a/src/profile.c b/src/profile.c
index 6bc6778de..70ac058f4 100644
--- a/src/profile.c
+++ b/src/profile.c
@@ -563,7 +563,7 @@ 
 			<text value=\"%s\"/>				\
 		</attribute>						\
 		<attribute id=\"0x0317\">				\
-			<uint32 value=\"0x0000007f\"/>			\
+			<uint32 value=\"0x0000027f\"/>			\
 		</attribute>						\
 		<attribute id=\"0x0200\">				\
 			<uint16 value=\"%u\" name=\"psm\"/>		\