Go CLI using cobra with mount, unmount, status, and init subcommands. Unlocks via udisks2 D-Bus (passphrase/keyfile) or cryptsetup (FIDO2/TPM2) with ordered method fallback. Includes NixOS-specific LD_LIBRARY_PATH injection for systemd cryptsetup token plugins. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
27 lines
582 B
Go
27 lines
582 B
Go
package dbus
|
|
|
|
import (
|
|
"encoding/hex"
|
|
)
|
|
|
|
// AuthExternal returns an Auth that authenticates as the given user with the
|
|
// EXTERNAL mechanism.
|
|
func AuthExternal(user string) Auth {
|
|
return authExternal{user}
|
|
}
|
|
|
|
// AuthExternal implements the EXTERNAL authentication mechanism.
|
|
type authExternal struct {
|
|
user string
|
|
}
|
|
|
|
func (a authExternal) FirstData() ([]byte, []byte, AuthStatus) {
|
|
b := make([]byte, 2*len(a.user))
|
|
hex.Encode(b, []byte(a.user))
|
|
return []byte("EXTERNAL"), b, AuthOk
|
|
}
|
|
|
|
func (a authExternal) HandleData(b []byte) ([]byte, AuthStatus) {
|
|
return nil, AuthError
|
|
}
|