goldwarden-vaultwarden-bitw.../cli/client/unixsocketclient.go

113 lines
2.8 KiB
Go
Raw Normal View History

2023-08-21 13:52:06 +02:00
package client
import (
2023-09-20 03:05:44 +02:00
"encoding/json"
2023-08-21 13:52:06 +02:00
"io"
"net"
2024-02-18 06:08:37 +01:00
"os"
2023-08-21 13:52:06 +02:00
2024-05-04 01:06:24 +02:00
"github.com/quexten/goldwarden/cli/agent/config"
"github.com/quexten/goldwarden/cli/ipc/messages"
2023-08-21 13:52:06 +02:00
)
2024-02-17 11:30:16 +01:00
const READ_BUFFER = 4 * 1024 * 1024 // 16MB
2023-08-21 13:52:06 +02:00
type UnixSocketClient struct {
2023-12-30 18:53:01 +01:00
runtimeConfig *config.RuntimeConfig
2023-08-21 13:52:06 +02:00
}
2024-02-09 00:24:28 +01:00
type UnixSocketConnection struct {
conn net.Conn
}
2023-12-30 18:53:01 +01:00
func NewUnixSocketClient(runtimeConfig *config.RuntimeConfig) UnixSocketClient {
return UnixSocketClient{
runtimeConfig: runtimeConfig,
}
2023-08-21 13:52:06 +02:00
}
2024-02-09 00:24:28 +01:00
func Reader(r io.Reader) interface{} {
2023-08-21 13:52:06 +02:00
buf := make([]byte, READ_BUFFER)
for {
n, err := r.Read(buf[:])
if err != nil {
return nil
}
2023-09-20 03:05:44 +02:00
var message messages.IPCMessage
err = json.Unmarshal(buf[0:n], &message)
2023-08-21 13:52:06 +02:00
if err != nil {
panic(err)
}
return message
}
}
func (client UnixSocketClient) SendToAgent(request interface{}) (interface{}, error) {
2024-02-09 00:24:28 +01:00
c, err := client.Connect()
2023-08-21 13:52:06 +02:00
if err != nil {
return nil, err
}
defer c.Close()
2024-02-09 00:24:28 +01:00
return c.SendCommand(request)
}
2023-08-21 13:52:06 +02:00
2024-02-09 00:24:28 +01:00
func (client UnixSocketClient) Connect() (UnixSocketConnection, error) {
2024-02-18 06:08:37 +01:00
runtimeConfig := client.runtimeConfig
home, err := os.UserHomeDir()
if err != nil {
panic(err)
}
if runtimeConfig.SSHAgentSocketPath == "" {
2024-02-22 14:38:38 +01:00
if _, err := os.Stat(home + "/.goldwarden-ssh-agent.sock"); err == nil {
runtimeConfig.SSHAgentSocketPath = home + "/.goldwarden-ssh-agent.sock"
2024-02-18 06:08:37 +01:00
} else if _, err := os.Stat(home + "/.var/app/com.quexten.Goldwarden/data/ssh-auth-sock"); err == nil {
runtimeConfig.SSHAgentSocketPath = home + "/.var/app/com.quexten.Goldwarden/data/ssh-auth-sock"
}
}
if runtimeConfig.GoldwardenSocketPath == "" {
if _, err := os.Stat(home + "/.goldwarden.sock"); err == nil {
runtimeConfig.GoldwardenSocketPath = home + "/.goldwarden.sock"
} else if _, err := os.Stat(home + "/.var/app/com.quexten.Goldwarden/data/goldwarden.sock"); err == nil {
runtimeConfig.GoldwardenSocketPath = home + "/.var/app/com.quexten.Goldwarden/data/goldwarden.sock"
}
}
2024-02-09 00:24:28 +01:00
c, err := net.Dial("unix", client.runtimeConfig.GoldwardenSocketPath)
2023-08-21 13:52:06 +02:00
if err != nil {
2024-02-09 00:24:28 +01:00
return UnixSocketConnection{}, err
2023-08-21 13:52:06 +02:00
}
2024-02-09 00:24:28 +01:00
return UnixSocketConnection{conn: c}, nil
}
func (conn UnixSocketConnection) SendCommand(request interface{}) (interface{}, error) {
err := conn.WriteMessage(request)
2023-08-21 13:52:06 +02:00
if err != nil {
2024-02-09 00:24:28 +01:00
return nil, err
2023-08-21 13:52:06 +02:00
}
2024-02-09 00:24:28 +01:00
return conn.ReadMessage(), nil
}
func (conn UnixSocketConnection) ReadMessage() interface{} {
result := Reader(conn.conn)
payload := messages.ParsePayload(result.(messages.IPCMessage))
return payload
}
2023-08-21 13:52:06 +02:00
2024-02-09 00:24:28 +01:00
func (conn UnixSocketConnection) WriteMessage(message interface{}) error {
messagePacket, err := messages.IPCMessageFromPayload(message)
2023-08-21 13:52:06 +02:00
if err != nil {
2024-02-09 00:24:28 +01:00
panic(err)
2023-08-21 13:52:06 +02:00
}
2024-02-09 00:24:28 +01:00
messageJson, err := json.Marshal(messagePacket)
if err != nil {
panic(err)
}
_, err = conn.conn.Write(messageJson)
return err
}
func (conn UnixSocketConnection) Close() {
conn.conn.Close()
2023-08-21 13:52:06 +02:00
}