I’ve created a snap of WireGuard’s userspace implementation, which appears to work well in devmode. But after confinement, I get an error as soon as the engine starts up and tries to write to /var/run:
mkdir /var/run/wireguard: permission denied
This is not surprising of course, as the snap doesn’t have write access to that path. What options to I have to get this to run?
To be clear, the program itself doesn’t appear to have an option flag that would make it save its runtime socket file elsewhere (though I also haven’t looked way too hard). I could patch the codebase of course, but I’d rather look for another solution first.
just to make sure it’s not an issue with tmpfs, but still got the same error about not being able to open /var/run/. Of course there are a few other permutations I could try, but I thought I’d see if you have any ideas.
I wanted to tick off some potential causes of the above:
I’m running the command with sudo
/var/run does exist
/var/run/wireguard doesn’t exist
But…it appears that /var/run is actually a symlink to /run. Could that be the problem? Also /run itself is a tmpfs, though I assume that should be fine. I’m running this on a pretty standard Ubuntu 18.04 install
Hey. I will investigate this today. Note that to see what really happens you cannot just look at the files on your host and on the initial mount namespace. Snapd does a lot of tricks to let apps run.
Thanks a lot for taking a look! And yes, appreciate there’s a lot happening under the hood. I mainly wanted to do some basic sanity checks, at least against the prerequisites you set out in the layout documentation thread.
Do let me know if there’s something else I should try (or logs I should look at, etc) in the meantime.
I will look at this now. I will add a spread test to ensure this functionality is explicitly tested with every pull request and release of snapd.
EDIT: so, quick test aside, with /var/run being a symlink to /run we are in risky waters. Snapd rightfully refuses to mount through a symbolic link of /var/run -> /run.
In addition snapd performs layout validation and refuses allow changing /run because some of the places there are sensitive.
I think that right now we need a new interface for Wireshark that would allow it to write to /run/wireshark for real.
Some casual googling (e.g. https://stackoverflow.com/a/25136221) leads me to believe that this error is due to the fact that the socket file is not in an appropriate/allowable location. So it seems I’m back to square one. Any ideas?
Thanks for the tip @ogra. I was hoping that would be it but after adding and connecting the interface I get the same behavior. The following is what I get in the log:
Nov 11 15:20:07 ubuntu-vm systemd-udevd[81075]: link_config: autonegotiation is unset or enabled, the speed and duplex are not writable.
Nov 11 15:20:07 ubuntu-vm kernel: [55513.384117] audit: type=1326 audit(1541946007.299:810): auid=1000 uid=0 gid=0 ses=38 pid=81038 comm="wireguard-go" exe="/snap/wireguard-ammp/49/usr/bin/wireguard-go" sig=0 arch=c000003e syscall=50 compat=0 ip=0x48a550 code=0x50000
Nov 11 15:20:07 ubuntu-vm networkd-dispatcher[30172]: WARNING:Unknown index 18 seen, reloading interface list
Nov 11 15:20:07 ubuntu-vm systemd-udevd[81075]: Process '/bin/sh -c 'echo 180 >/sys$DEVPATH/timeout'' failed with exit code 2.
Nov 11 15:20:07 ubuntu-vm networkd-dispatcher[30172]: ERROR:Unknown interface index 18 seen even after reload
Nov 11 15:20:07 ubuntu-vm systemd-udevd[81075]: Process '/bin/sh -c 'echo 180 >/sys$DEVPATH/timeout'' failed with exit code 2.
Nov 11 15:20:07 ubuntu-vm systemd-udevd[81079]: Process '/bin/sh -c 'echo 180 >/sys$DEVPATH/timeout'' failed with exit code 2.
well, the audit message talks about syscall=50 … which is listen() on x86 … you now made me check network-bind and it clearly defines the listen syscall, which is weird:
is your snapcraft.yaml on GH up to date ? i dont see network-bind defined for wireguard-go…
…yes, that’s because I had accidentally mis-assigned the interface in the snapcraft.yaml. Thanks @ogra for going the extra mile to figure that out.
With the network-bind interface correctly associated with wireguard-go, the whole thing appears to work 100% now!
I’ll leave this open for now since the original question regarding access to /var/run remains. In the meantime, if anyone’s looking for a functioning WireGuard snap it’s here: https://snapcraft.io/wireguard-ammp
Yup, good point @pachulo! Having a patch was my original vision for how to do it also - and I agree is a better long-term solution. The fork+edit seemed more straightforward for a proof-of-concept. Ideally of course I would be able to get the upstream developers to make the change (or something like it), which is sensible from a functionality perspective anyway
Has there been any update on getting an interface to allow a strict mode snap to access files in /var/run? I also have an application that needs to talk to a closed source driver that places socket files and such in /var/run.
@olympionex - fyi, these days snapd allows snaps to create/use a snap-specific directory in /run/snap.<snap name>/ and any commands within the snap are able to access those files. That should cover many use cases. For snap-to-snap communication, that can either be done via the content interface or implementing an application specific interface, like with mir, udisks2, etc. It really depends on the situation. You may want to start a new topic if this doesn’t meet your needs and can discuss paths forward.
/me notes that /var/run is typically a symlink to /run these days