It's been a day and I still don't grok kernel keyring possession.
I'd like a garbage collected anonymouss keyring for my ssh-agent, but it for some reason I can't run add_key own the process keyring 🙃
=> More informations about this toot | More toots from Foxboron@chaos.social
Turns out the second you start a goroutine in Go, your loose possession of the session keyring. And then nothing really works?
Do I have to write a key peddler with a locked OS thread that just peddles keys between channels?
=> More informations about this toot | More toots from Foxboron@chaos.social
@Foxboron any pointer to code and/or details about this/
=> More informations about this toot | More toots from quitelost@mastodon.social
@quitelost
A reproducer here. The signal.Notify
creates a gorutines that on my end doesn't allow me to look at the keyring anymore.
https://github.com/Foxboron/test-keyring/blob/master/main.go
=> More informations about this toot | More toots from Foxboron@chaos.social
@quitelost
Cc @paul
If you happen to know why the kernel keyring fail in the above example code :)
As you wrote go-keyring at some point in time.
=> More informations about this toot | More toots from Foxboron@chaos.social
@Foxboron @quitelost I've def been able to use goroutines and keyrings.
Check this out; I think it's signal handling (which is incredibly ... invasive ... in go)
https://gist.github.com/paultag/41ce383d6592146d1e912aaef3a4c811
=> More informations about this toot | More toots from paul@soylent.green
@Foxboron
(output:)
created keyring
883195902 1
addkey this works 883195902 1
addkey this works again 883195902 1
addkey this works does not work 883195902 1
(success)
=> More informations about this toot | More toots from paul@soylent.green
@Foxboron Also, unrelated, but you're welcome to take over pault.ag/go/keyring; I can move you the repo / add you to it, always down to collab with you again obviously
=> More informations about this toot | More toots from paul@soylent.green
@paul
I'll POC things up in my ssh-tpm-agent code for some quick iterations for a v1.0 release there I think, i have a FOSDEM presentation deadline :p
But longterm i suspect this can be added to go-keyring and I wouldn't mind helping to maintain it.
=> More informations about this toot | More toots from Foxboron@chaos.social
@Foxboron I'm unfortunately a bit short on time this week but my next steps are some strace between the binaries with signal handler and without, and work backwards to figure out what's different with the syscalls
=> More informations about this toot | More toots from paul@soylent.green
@paul
We sorta figured it out. The signal handling does a switcheroo on the pid/tid of the process so we loose possession of the session keyring.
The solution is to run all keyctl syscalls in a separate goroutine with LockOSThread.
I suspect this is a nice addition to your go-keyring :)
=> More informations about this toot | More toots from Foxboron@chaos.social This content has been proxied by September (ba2dc).Proxy Information
text/gemini