aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorTed Gould <ted@gould.cx>2014-02-11 16:29:54 -0600
committerTed Gould <ted@gould.cx>2014-02-11 16:29:54 -0600
commitb96572e7933c03fdd51529e6dd71e87c72bd062a (patch)
treebdfdf050bb606ede1758da017c441bc66ba418b6 /src
parenteb1dc0ff1ae607763635ad220b7b914ec9235417 (diff)
downloadayatana-indicator-sound-b96572e7933c03fdd51529e6dd71e87c72bd062a.tar.gz
ayatana-indicator-sound-b96572e7933c03fdd51529e6dd71e87c72bd062a.tar.bz2
ayatana-indicator-sound-b96572e7933c03fdd51529e6dd71e87c72bd062a.zip
Build up to getting our settings proxy in the account manager
Diffstat (limited to 'src')
-rw-r--r--src/accounts-service-user.vala39
1 files changed, 38 insertions, 1 deletions
diff --git a/src/accounts-service-user.vala b/src/accounts-service-user.vala
index 33fb6e9..c476033 100644
--- a/src/accounts-service-user.vala
+++ b/src/accounts-service-user.vala
@@ -17,16 +17,53 @@
* Ted Gould <ted@canonical.com>
*/
+[DBus (name = "com.canonical.indicator.sound.AccountsService")]
+public interface AccountsServiceSoundSettings : Object {
+ // properties
+ public abstract bool playing{owned get; set;}
+}
public class AccountsServiceUser : Object {
Act.UserManager accounts_manager = Act.UserManager.get_default();
Act.User? user = null;
+ AccountsServiceSoundSettings? proxy = null;
+ MediaPlayer? _player = null;
- public MediaPlayer? player = null;
+ public MediaPlayer? player {
+ set {
+ this._player = value;
+ }
+ get {
+ return this._player;
+ }
+ }
public AccountsServiceUser () {
user = accounts_manager.get_user(GLib.Environment.get_user_name());
+ user.notify["is-loaded"].connect(() => {
+ debug("User loaded");
+
+ this.proxy = null;
+
+ Bus.get_proxy.begin<AccountsServiceSoundSettings> (
+ BusType.SYSTEM,
+ "org.freedesktop.AccountsService",
+ user.get_object_path(),
+ DBusProxyFlags.GET_INVALIDATED_PROPERTIES,
+ null,
+ new_proxy);
+ });
+
+ }
+ void new_proxy (GLib.Object? obj, AsyncResult res) {
+ try {
+ this.proxy = Bus.get_proxy.end (res);
+ //this.player = _player;
+ } catch (Error e) {
+ this.proxy = null;
+ warning("Unable to get proxy to user sound settings: %s", e.message);
+ }
}