/etc/dbus-1/system.d/
に例-dbus.confファイルは次のようになります。
<!DOCTYPE busconfig PUBLIC
"-//freedesktop//DTD D-BUS Bus Configuration 1.0//EN"
"http://www.freedesktop.org/standards/dbus/1.0/busconfig.dtd">
<busconfig>
<!-- Only root user can own the service -->
<policy user="root">
<allow own="com.company.qtdbus"/>
</policy>
<!-- Allow anyone to invoke methods on server, except SetHostName -->
<policy context="default">
<allow send_destination="com.company.qtdbus"/>
<allow receive_sender="com.company.qtdbus"/>
<deny send_destination="com.company.qtdbus"
send_interface="com.company.qtdbus.Server" send_member="SetHostName"/>
</policy>
<!-- Allow everything, including access to SetHostName -->
<policy user="root">
<allow send_destination="com.company.qtdbus"/>
<allow receive_sender="com.company.qtdbus"/>
</policy>
</busconfig>
を再起動してdbusのデーモン/etc/init.d/d-bus restart
これで、システムバスに接続することを許可する必要があります。実際に、システムバスに接続できない場合は、エラーメッセージが表示されます。
出典
2013-10-02 10:37:17
MeJ
私はポリシーの問題を考える。 '/ etc/dbus-1/system.d'にconfファイルを追加しますか?私は同じ問題を抱えていましたが、私はconfigファイルを変更して解決しました。 –