diff --git a/conn_unix.go b/conn_unix.go index 1a0daa6..a982e7f 100644 --- a/conn_unix.go +++ b/conn_unix.go @@ -4,6 +4,7 @@ package dbus import ( + "net" "os" ) @@ -16,3 +17,28 @@ func getSystemBusPlatformAddress() string { } return defaultSystemBusAddress } + +// DialUnix establishes a new private connection to the message bus specified by UnixConn. +func DialUnix(conn *net.UnixConn, opts ...ConnOption) (*Conn, error) { + tr, err := newUnixTransportFromConn(conn) + if err != nil { + return nil, err + } + return newConn(tr, opts...) +} + +func ConnectUnix(uconn *net.UnixConn, opts ...ConnOption) (*Conn, error) { + conn, err := DialUnix(uconn, opts...) + if err != nil { + return nil, err + } + if err = conn.Auth(conn.auth); err != nil { + _ = conn.Close() + return nil, err + } + if err = conn.Hello(); err != nil { + _ = conn.Close() + return nil, err + } + return conn, nil +} diff --git a/transport_unix.go b/transport_unix.go index 6840387..146ccd4 100644 --- a/transport_unix.go +++ b/transport_unix.go @@ -55,6 +55,14 @@ type unixTransport struct { hasUnixFDs bool } +func newUnixTransportFromConn(conn *net.UnixConn) (transport, error) { + t := new(unixTransport) + t.UnixConn = conn + t.hasUnixFDs = true + + return t, nil +} + func newUnixTransport(keys string) (transport, error) { var err error