[RFC] API for MAP client in obex-client

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,
below proposed API for MAP client in obex-client, for now just some
generic functions and browsing support.

Messages Access hierarchy
=========================

Service         org.openobex.client
Interface       org.openobex.MessagesAccess
Object path     [variable prefix]/{session0,session1,...}

Methods         dict(uint8 tag, variant value) GetAppParams()

                       Retrieve application parameters connected to the last MSE
                       response. Application parameters corresponding
to given call
                       are accessible until next request is sent.

                       Parameters are converted to unsigned integers
of corresponding sizes
                       (MAP specification section 6.3.1) or
NULL-terminated strings.
                       In case of parameters not mentioned in MAP
specification value
                       becomes struct of (uint8 length, array{uint8}).

                       See MAP specification (section corresponding to
given function)
                       for more details on returned parameters.

               void SetFolder(boolean cdup, string name)

                       Set working directory for current session.

                       |  cdup  | folder name | operation    |
                       |=====================================|
                       | FALSE  | empty       | cd /         |
                       |--------+-------------+--------------|
                       | FALSE  | name        | cd name      |
                       |--------+-------------+--------------|
                       | TRUE   | [name]      | cd ..[/name] |
                       +-------------------------------------+

               array{dict(string property, string value)}
               GetFolderListing(dict(uint8 tag, uint16 value))

                       Retrieve list of names (and all other
properties returned by MSE)
                       for directories in CWD.

                       Parameters as in MAP specification section 5.4.

               array{dict(string property, string value)}
               GetMessageListing(string folder, array{uint8 tag, variant value})

                       Return message listing for given subfolder of
CWD or directly
                       CWD if folder field is empty, format of each dict entry
                       corresponds to the message listing format (MAP
specification
                       section 3.1.6).

                       Parameters as in MAP specification section 5.5.

               unix_fd msgfd
               GetMessage(string handle, dict(uint8 tag, variant value))

                       Retrieve message from remote device and return
file descriptor,
                       from which message data (in BMSG format) may be read.

                       Parameters as in MAP specification section 5.6.

               void SetMessageStatus(string handle, uint8 indicator,
uint8 value)

                       Modify status of a message on remote device.

                       Parameters as in MAP specification section 5.7.

               void UpdateInbox()

                       Initiate update of inbox status on remote device.

-- 
Pozdrowienia - Cheers,
Bartosz Szatkowski
--
To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Bluez Devel]     [Linux Wireless Networking]     [Linux Wireless Personal Area Networking]     [Linux ATH6KL]     [Linux USB Devel]     [Linux Media Drivers]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Big List of Linux Books]

  Powered by Linux