Heim > Backend-Entwicklung > Golang > Fehler org.freedesktop.DBus.Error.UnknownMethod: Unbekannte/ungültige Methode „Notify'

Fehler org.freedesktop.DBus.Error.UnknownMethod: Unbekannte/ungültige Methode „Notify'

PHPz
Freigeben: 2024-02-06 08:00:17
nach vorne
1282 Leute haben es durchsucht

错误 org.freedesktop.DBus.Error.UnknownMethod:未知/无效方法“Notify”

Frageninhalt

Ich versuche, mit Godbus einen Benachrichtigungsserver zu erstellen, aber ich kann mein Serverobjekt nicht korrekt nach Dbus exportieren und Dbus erkennt nur meine Selbstprüfungs-XML. Ich bin https://pecifications.freedesktop.org/notification-spec/notification-spec-latest.html gefolgt, um es zu implementieren. Ich verwende auch _example/server.go im Godbus-Repository, was Ihnen vielleicht im unten bereitgestellten Servercode auffällt. Dies ist der Servercode:

package main

import (
    "fmt"
    "os"

    "github.com/godbus/dbus/v5"
    "github.com/godbus/dbus/v5/introspect"
)

const xml = `
<node>
    <interface name="org.freedesktop.notifications">
        <method name="notify">
            <arg direction="in" type="s"/>
            <arg direction="in" type="u"/>
            <arg direction="in" type="s"/>
            <arg direction="in" type="s"/>
            <arg direction="in" type="s"/>
            <arg direction="in" type="as"/>
            <arg direction="in" type="a{sv}"/>
            <arg direction="in" type="i"/>
            <arg direction="out" type="u"/>
        </method>

        <method name="getcapabilities">
            <arg direction="out" type="as"/>
        </method>

        <method name="getserverinformation">
            <arg direction="out" type="s"/>
            <arg direction="out" type="s"/>
            <arg direction="out" type="s"/>
            <arg direction="out" type="s"/>
        </method>

        <method name="closenotification">
            <arg direction="in" type="u"/>
        </method>

        <signal name="notificationclosed">
            <arg type="u" name="id"/>
            <arg type="u" name="reason"/>
        </signal>
    </interface>` + introspect.introspectdatastring + `</node> `

type notificationserver struct {
}

func (s *notificationserver) notify(appname string, replacesid uint32, appicon string, summary string, body string, actions []string, hints map[string]dbus.variant, expiretimeout int32) (uint32, *dbus.error) {
    fmt.printf("new notification: %s\n", body)
    return 0, nil
}

func (s *notificationserver) getcapabilities() ([]string, *dbus.error) {
    return []string{"action-icons", "actions", "body", "body-hyperlinks", "body-images", "body-markup", "icon-multi", "icon-static", "persistence", "sound"}, nil
}

func (s *notificationserver) getserverinformation() (string, string, string, string, *dbus.error) {
    return "antarctica", "antarctica.com", "1.0", "1.2", nil
}

func (s *notificationserver) closenotification(id uint32) *dbus.error {
    s.notificationclosed(id, 0)
    return nil
}
func (s *notificationserver) notificationclosed(id, reason uint32) {

}

func main() {
    conn, err := dbus.connectsessionbus()
    if err != nil {
        panic(err)
    }
    defer conn.close()

    reply, err := conn.requestname("com.antarctica.notification",
        dbus.nameflagdonotqueue)
    if err != nil {
        panic(err)
    }

    if reply != dbus.requestnamereplyprimaryowner {
        fmt.fprintln(os.stderr, "name already taken")
        os.exit(1)
    }
    server := notificationserver{}
    err = conn.export(server,"/org/freedesktop/notifications","org.freedesktop.notifications")
    if err != nil {
        panic(err)
    }
    conn.export(introspect.introspectable(xml), "/org/freedesktop/notifications", "org.freedesktop.dbus.introspectable")
    fmt.println("listening on com.antarctica.notification / /com/antarctica/notification ...")
    select {}
}
Nach dem Login kopieren

Das Problem besteht nun darin, dass, selbst wenn der Client Zugriff auf die Introspection-XML hat:

$ gdbus introspect --session --dest com.antarctica.notification --object-path /org/freedesktop/notifications --xml

> returns xml
Nach dem Login kopieren

Ich kann die Methode org.freedesktop.notifications, die ich im Servercode geschrieben habe, nicht verwenden. Beispielsweise ist notify unbekannt/ungültig, was für jede Methode gleich ist:

$ dbus-send --session --print-reply=literal --dest=com.antarctica.notification /org/freedesktop/Notifications org.freedesktop.Notifications.Notify

> Error org.freedesktop.DBus.Error.UnknownMethod: Unknown / invalid method 'Notify'
Nach dem Login kopieren

Wenn ich in qdbusviewer versuche, eine Methode auszuführen, heißt es außerdem: „Methode x konnte im Pfad /org/freedesktop/notifications in der Schnittstelle org.freedesktop.notifications nicht gefunden werden“

Was ich versucht habe:

  1. Überprüfen Sie, ob dbus läuft
  2. Überprüfen Sie, ob mein Server läuft
  3. Ich habe auch versucht, den Dbus-Dienst und meinen Computer neu zu starten
  4. Ich glaube, die Notificationserver-Instanz (Server) wird überhaupt nicht exportiert, aber ich weiß nicht warum


Richtige Antwort


Das funktioniert. Du hast zwei Fehler gemacht:

  1. com.antarktica.notification
  2. func (s *Benachrichtigungsserver)

Sie müssen „org.freedesktop.notifications“ als Namen anfordern und dürfen keine Zeiger in Funktionen verwenden.

  1. org.freedesktop.notifications
  2. func (Benachrichtigungsserver)
  3. (Sie müssen auch nicht nach innen schauen)
package main

import (
    "fmt"
    "os"

    "github.com/godbus/dbus/v5"
)

type notificationServer struct{}

func (s notificationServer) Notify(appName string, replacesID uint32, appIcon string, summary string, body string, actions []string, hints map[string]dbus.Variant, expireTimeout int32) (uint32, *dbus.Error) {
    fmt.Printf("New notification: %s\n", body)
    return 0, nil
}

func (s notificationServer) GetCapabilities() ([]string, *dbus.Error) {
    return []string{"action-icons", "actions", "body", "body-hyperlinks", "body-images", "body-markup", "icon-multi", "icon-static", "persistence", "sound"}, nil
}

func (s notificationServer) GetServerInformation() (string, string, string, string, *dbus.Error) {
    return "antarctica", "antarctica.com", "1.0", "1.2", nil
}

func main() {
    conn, err := dbus.ConnectSessionBus()
    if err != nil {
        panic(err)
    }
    defer conn.Close()

    f := notificationServer{}
    conn.Export(f, "/org/freedesktop/Notifications", "org.freedesktop.Notifications")

    reply, err := conn.RequestName("org.freedesktop.Notifications", dbus.NameFlagDoNotQueue)
    if err != nil {
        panic(err)
    }
    if reply != dbus.RequestNameReplyPrimaryOwner {
        fmt.Fprintln(os.Stderr, "name already taken")
        os.Exit(1)
    }
    fmt.Println("Listening...")
    select {}
}
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonFehler org.freedesktop.DBus.Error.UnknownMethod: Unbekannte/ungültige Methode „Notify'. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:stackoverflow.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage