Skip to content

Commit

Permalink
feat: support static connection info (#648)
Browse files Browse the repository at this point in the history
Add support for seeding the connection info cache with static
certificates and IP addresses. This is useful in development contexts
and should otherwise be considered a non-production feature.

With this commit, callers may now provide the path to a JSON file which
contains an RSA key pair, IP addresses, and certificate chains for any
number of AlloyDB instances.

NOTE: the file format is subject to breaking changes. As such this
feature should be considered for development only.
  • Loading branch information
enocom authored May 15, 2024
1 parent c6accf0 commit 78c3131
Show file tree
Hide file tree
Showing 3 changed files with 56 additions and 0 deletions.
26 changes: 26 additions & 0 deletions cmd/root.go
Original file line number Diff line number Diff line change
Expand Up @@ -370,6 +370,30 @@ Third Party Licenses
distribution please see:
https://storage.googleapis.com/alloydb-auth-proxy/v1.9.0/third_party/licenses.tar.gz {x-release-please-version}
Static Connection Info
In development contexts, it can be helpful to populate the Proxy with static
connection info. This is a *dev-only* feature and NOT for use in production.
The file format is subject to breaking changes.
The format is:
{
"publicKey": "<PEM Encoded public RSA key>",
"privateKey": "<PEM Encoded private RSA key>",
"projects/<PROJECT>/locations/<REGION>/clusters/<CLUSTER>/instances/<INSTANCE>": {
"ipAddress": "<PSA-based private IP address>",
"publicIpAddress": "<public IP address>",
"pscInstanceConfig": {
"pscDnsName": "<PSC DNS name>"
},
"pemCertificateChain": [
"<client cert>", "<intermediate cert>", "<CA cert>"
],
"caCert": "<CA cert>"
}
}
`

var waitHelp = `
Expand Down Expand Up @@ -597,6 +621,8 @@ the cached copy has expired. Use this setting in environments where the
CPU may be throttled and a background refresh cannot run reliably
(e.g., Cloud Run)`,
)
localFlags.StringVar(&c.conf.StaticConnectionInfo, "static-connection-info",
"", "JSON file with static connection info. See --help for format.")

// Global and per instance flags
localFlags.StringVarP(&c.conf.Addr, "address", "a", "127.0.0.1",
Expand Down
11 changes: 11 additions & 0 deletions cmd/root_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -510,6 +510,17 @@ func TestNewCommandArguments(t *testing.T) {
DebugLogs: true,
}),
},
{
desc: "using the static connection info flag",
args: []string{
"--static-connection-info",
"myfile.json",
"projects/proj/locations/region/clusters/clust/instances/inst",
},
want: withDefaults(&proxy.Config{
StaticConnectionInfo: "myfile.json",
}),
},
}

for _, tc := range tcs {
Expand Down
19 changes: 19 additions & 0 deletions internal/proxy/proxy.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
package proxy

import (
"bytes"
"context"
"fmt"
"io"
Expand Down Expand Up @@ -206,6 +207,10 @@ type Config struct {
// RunConnectionTest determines whether the Proxy should attempt a connection
// to all specified instances to verify the network path is valid.
RunConnectionTest bool

// StaticConnectionInfo is the file path for a static connection info JSON
// file. See the proxy help message for details on its format.
StaticConnectionInfo string
}

// dialOptions interprets appropriate dial options for a particular instance
Expand Down Expand Up @@ -335,6 +340,20 @@ func (c *Config) DialerOptions(l alloydb.Logger) ([]alloydbconn.Option, error) {
if c.LazyRefresh {
opts = append(opts, alloydbconn.WithLazyRefresh())
}
if c.StaticConnectionInfo != "" {
f, err := os.Open(c.StaticConnectionInfo)
if err != nil {
return nil, err
}
defer f.Close()
data, err := io.ReadAll(f)
if err != nil {
return nil, err
}
opts = append(opts, alloydbconn.WithStaticConnectionInfo(
bytes.NewReader(data),
))
}

return opts, nil
}
Expand Down

0 comments on commit 78c3131

Please sign in to comment.