Active Topics

 


Reply
Thread Tools
kif's Avatar
Posts: 60 | Thanked: 40 times | Joined on May 2010 @ Skovballe, Denmark
#1
Hi

I'm trying to access the contacts from a daemon (using Qt), but whenever i try to create an instance of QContactManager the daemon exits.

My rutines works in a test program, but not in the daemon.

Any ideas what is wrong, and how to solve it ?

Could it be because the daemon is running as root ?

Thanks
 
eitama's Avatar
Posts: 702 | Thanked: 334 times | Joined on Feb 2010 @ Israel.
#2
Originally Posted by kif View Post
Hi

I'm trying to access the contacts from a daemon (using Qt), but whenever i try to create an instance of QContactManager the daemon exits.

My rutines works in a test program, but not in the daemon.

Any ideas what is wrong, and how to solve it ?

Could it be because the daemon is running as root ?

Thanks
As far as I know the Qt Api requires user permissions. To debug out better maybe you can use gdb.
__________________
| Developer of Horizontal-Call - Call your contacts, fast! |
| Reverse SSH - access your N900 from anywhere, anytime |
| Using Samsung Galaxy S GT-i9000 and Nokia N900 |
| DonateMe - If you feel I helped you in a very good way, feel free to donate |
 
kif's Avatar
Posts: 60 | Thanked: 40 times | Joined on May 2010 @ Skovballe, Denmark
#3
I had an feeling it could be something like that, how do I make a daemon run with user permissions ?

Kim
 
eitama's Avatar
Posts: 702 | Thanked: 334 times | Joined on Feb 2010 @ Israel.
#4
Originally Posted by kif View Post
I had an feeling it could be something like that, how do I make a daemon run with user permissions ?

Kim
Try running it with "runstandalone.sh <scriptName>"
I just guessing though, never wrote a deamon.
__________________
| Developer of Horizontal-Call - Call your contacts, fast! |
| Reverse SSH - access your N900 from anywhere, anytime |
| Using Samsung Galaxy S GT-i9000 and Nokia N900 |
| DonateMe - If you feel I helped you in a very good way, feel free to donate |
 
kif's Avatar
Posts: 60 | Thanked: 40 times | Joined on May 2010 @ Skovballe, Denmark
#5
It runs without any problems as user, but I need it to run automatically at startup.

Does anyone know how to start a daemon with user permissions from an event.d script ?

Kim.
 
nicolai's Avatar
Posts: 1,637 | Thanked: 4,424 times | Joined on Apr 2009 @ Germany
#6
The problem isn't root or user permission but the
dbus session.
To access users contacts you need the correct
user dbus session.
You may look at other programs like headphoned how to
connect/setup sessionbus.

nicolai
 
kif's Avatar
Posts: 60 | Thanked: 40 times | Joined on May 2010 @ Skovballe, Denmark
#7
Hi nicolai

Thanks for your answer, and sorry for the long delay, I was busy elsewhere.

I have had a long hard look at headphoned and other daemon projects, and as far as I can see all it requires to get the dbus session address is to execute /tmp/session_bus_address.user to export the dbus address before starting my daemon.

Unfortunatly that didn't help.

Any other ideas, I have an almost finished daemon, I just need this to make it usable

Kim
 
nicolai's Avatar
Posts: 1,637 | Thanked: 4,424 times | Joined on Apr 2009 @ Germany
#8
Any hints what happens when your daemon creates the QContactManager?
Some logging output in /var/log/syslog?

Maybe your daemon starts too early.
I don't know anything about the internals of QContactManager. But
I think it doesn't only needs a sessionbus connection but
the contacts backend (osso-addressbook and evolution) must be
running and be available through dbus, as well.

nicolai
 
kif's Avatar
Posts: 60 | Thanked: 40 times | Joined on May 2010 @ Skovballe, Denmark
#9
No sorry, nothing in any log file.

I have placed some debug logging in the code and it is at this line the daemon exits :

QContactManager *m_manager = new QContactManager();

If I start the daemon as user in xterminal everything works as planned.

If I start the daemon as root in xterminal, the daemon starts, but the moment a call is registered, and the daemon try to find the phone number in contacts it exits (same result when the daemon is started at boot) !

I have tried to log the enviroment variables, and in both cases DBUS_SESSION_BUS_ADDRESS has the same value !

Kim.
 
nicolai's Avatar
Posts: 1,637 | Thanked: 4,424 times | Joined on Apr 2009 @ Germany
#10
Originally Posted by kif View Post
No sorry, nothing in any log file.
Do you have sysklogd installed?

Nicolai
 
Reply


 
Forum Jump


All times are GMT. The time now is 21:33.