implement upower interface
Affects | Status | Importance | Assigned to | Milestone | |
---|---|---|---|---|---|
Snappy |
Fix Released
|
Wishlist
|
Jamie Strandboge |
Bug Description
I am developing an application that constantly displays CPU usage and Battery status to the user. For the sake of simplicity, I launch bash (which itself launches other processes such as grep) to obtain the required information.
When I "snap" my application, Snappy's security model does not allow my application to launch bash as an external process. I am using the following programs/processes:
- grep
- awk
- upower
- bash (which launches the other processes with UNIX pipes)
If you need to check the code that I use to obtain CPU usage & battery info, please see:
https:/
You may want to check my snapcraft.yaml file:
https:/
Note that I have tried my application with both the "strict" and "devmode" confinements.
Is there any interface specific for my configuration, or must I change something in my snapcraft.yaml?
Thanks for the support!
Changed in snappy: | |
assignee: | nobody → Jamie Strandboge (jdstrand) |
status: | New → In Progress |
Thank you for reporting a bug. The fact that devmode is not working indicates something unrelated to interfaces is not quite working with your snap.
To be clear though, snaps can launch external processes and grep, awk and bash are all allowed in the default policy (upower is not and needs research) but the files they operate on may not be allowed by the security policy. I looked at the source code and see that:
* /proc/stat is currently not allowed. I'll add this to the system-observe interface
* the upower command is not available in the os snap, so your commands cannot succeed
I suspect it is this last point that is blocking you. If you included 'upower' in your stage packages, I suspect this would start to work in devmode.
For strict mode, upowerd is a DBus service that exists on classic systems but not native systems. To allow access to upowerd we'd need to create a new interface.
Based on the above, I'm going to change the title of this bug accordingly.
Note to snappy interfaces team: perhaps upower-observe and upower-control? I've not examined the DBus API to see if this is feasible, but I suspect it is so long as upower-observe can use DBus Get and upower-control can use DBus Set methods.