forked from security/hakurei
internal/pipewire: implement Core::Sync
Once again, already entirely supported, the offset is not yet fully verified but makes intuitive sense. Will verify this on future occurrences of the message. Signed-off-by: Ophestra <cat@gensokyo.uk>
This commit is contained in:
@@ -83,6 +83,34 @@ func (c *CoreHello) UnmarshalBinary(data []byte) error {
|
||||
return err
|
||||
}
|
||||
|
||||
const (
|
||||
// CoreSyncSequenceOffset is the offset to [Header.Sequence] to produce [CoreSync.Sequence].
|
||||
CoreSyncSequenceOffset = 0x40000000
|
||||
)
|
||||
|
||||
// The CoreSync message will result in a Done event from the server.
|
||||
// When the Done event is received, the client can be sure that all
|
||||
// operations before the Sync method have been completed.
|
||||
type CoreSync struct {
|
||||
// The id will be returned in the Done event,
|
||||
// ends up as [Header.ID] in a future message.
|
||||
ID Int
|
||||
// Usually generated automatically and will be
|
||||
// returned in the Done event.
|
||||
Sequence Int
|
||||
}
|
||||
|
||||
// MarshalBinary satisfies [encoding.BinaryMarshaler] via [MarshalAppend].
|
||||
func (c *CoreSync) MarshalBinary() ([]byte, error) {
|
||||
return MarshalAppend(make([]byte, 0, 40), c)
|
||||
}
|
||||
|
||||
// UnmarshalBinary satisfies [encoding.BinaryUnmarshaler] via [Unmarshal].
|
||||
func (c *CoreSync) UnmarshalBinary(data []byte) error {
|
||||
_, err := Unmarshal(data, c)
|
||||
return err
|
||||
}
|
||||
|
||||
// CoreGetRegistry is sent when a client requests to bind to the
|
||||
// registry object and list the available objects on the server.
|
||||
//
|
||||
|
||||
@@ -14,6 +14,15 @@ func TestCoreHello(t *testing.T) {
|
||||
}.run(t)
|
||||
}
|
||||
|
||||
func TestCoreSync(t *testing.T) {
|
||||
encodingTestCases[pipewire.CoreSync, *pipewire.CoreSync]{
|
||||
{"sample", []byte(sendmsg00Message03POD), pipewire.CoreSync{
|
||||
ID: pipewire.PW_ID_CORE,
|
||||
Sequence: pipewire.CoreSyncSequenceOffset + 3,
|
||||
}, nil},
|
||||
}.run(t)
|
||||
}
|
||||
|
||||
func TestCoreGetRegistry(t *testing.T) {
|
||||
encodingTestCases[pipewire.CoreGetRegistry, *pipewire.CoreGetRegistry]{
|
||||
{"sample", []byte(sendmsg00Message02POD), pipewire.CoreGetRegistry{
|
||||
|
||||
@@ -29,6 +29,12 @@ func TestHeader(t *testing.T) {
|
||||
Size: 0x28, Sequence: 2, FileCount: 0,
|
||||
}, nil},
|
||||
|
||||
{"PW_CORE_METHOD_SYNC", []byte(sendmsg00Message03Header), pipewire.Header{
|
||||
ID: pipewire.PW_ID_CORE,
|
||||
Opcode: pipewire.PW_CORE_METHOD_SYNC,
|
||||
Size: 0x28, Sequence: 3, FileCount: 0,
|
||||
}, nil},
|
||||
|
||||
{"PW_SECURITY_CONTEXT_METHOD_CREATE", []byte{
|
||||
// Id
|
||||
3, 0, 0, 0,
|
||||
|
||||
@@ -19,4 +19,9 @@ var (
|
||||
sendmsg00Message02Header string
|
||||
//go:embed testdata/05-sendmsg00-message02-POD
|
||||
sendmsg00Message02POD string
|
||||
|
||||
//go:embed testdata/06-sendmsg00-message03-header
|
||||
sendmsg00Message03Header string
|
||||
//go:embed testdata/07-sendmsg00-message03-POD
|
||||
sendmsg00Message03POD string
|
||||
)
|
||||
|
||||
BIN
internal/pipewire/testdata/06-sendmsg00-message03-header
vendored
Normal file
BIN
internal/pipewire/testdata/06-sendmsg00-message03-header
vendored
Normal file
Binary file not shown.
BIN
internal/pipewire/testdata/07-sendmsg00-message03-POD
vendored
Normal file
BIN
internal/pipewire/testdata/07-sendmsg00-message03-POD
vendored
Normal file
Binary file not shown.
Reference in New Issue
Block a user