Skip to content

Commit 72ea249

Browse files
authored
Add --metal flag for filtering cluster SKUs (#990)
* Update planetscale-go * Add metal and standard flags to size. * Remove ClusterSize typing * Use network instead of standard * Only have a metal flag * Fix conditional
1 parent fae64a2 commit 72ea249

File tree

9 files changed

+28
-20
lines changed

9 files changed

+28
-20
lines changed

go.mod

+2-2
Original file line numberDiff line numberDiff line change
@@ -23,7 +23,7 @@ require (
2323
github.com/mitchellh/go-homedir v1.1.0
2424
github.com/pkg/browser v0.0.0-20240102092130-5ac0b6a4141c
2525
github.com/pkg/errors v0.9.1
26-
github.com/planetscale/planetscale-go v0.124.0
26+
github.com/planetscale/planetscale-go v0.125.0
2727
github.com/planetscale/psdb v0.0.0-20240109164348-6848e728f6e7
2828
github.com/planetscale/psdbproxy v0.0.0-20250117221522-0c8e2b0e36e6
2929
github.com/spf13/cobra v1.9.1
@@ -34,7 +34,7 @@ require (
3434
go.uber.org/zap v1.27.0
3535
go.uber.org/zap/exp v0.3.0
3636
golang.org/x/exp v0.0.0-20240909161429-701f63a606c0
37-
golang.org/x/oauth2 v0.27.0
37+
golang.org/x/oauth2 v0.28.0
3838
golang.org/x/sync v0.11.0
3939
golang.org/x/sys v0.30.0
4040
golang.org/x/text v0.22.0

go.sum

+4-4
Original file line numberDiff line numberDiff line change
@@ -114,8 +114,8 @@ github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4=
114114
github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
115115
github.com/planetscale/noglog v0.2.1-0.20210421230640-bea75fcd2e8e h1:MZ8D+Z3m2vvqGZLvoQfpaGg/j1fNDr4j03s3PRz4rVY=
116116
github.com/planetscale/noglog v0.2.1-0.20210421230640-bea75fcd2e8e/go.mod h1:hwAsSPQdvPa3WcfKfzTXxtEq/HlqwLjQasfO6QbGo4Q=
117-
github.com/planetscale/planetscale-go v0.124.0 h1:WiPPBEJ0fpg9D9+X+lQC0i7Knb6cQ3yO38Xe90O/qwQ=
118-
github.com/planetscale/planetscale-go v0.124.0/go.mod h1:HXOe9UNFb71w9XIICJj5ncwuY25h2Bng/KrXH80GF0s=
117+
github.com/planetscale/planetscale-go v0.125.0 h1:+R8ZZ0nW+HZhFJGU9IQQxREXM9r7YX6u+S61mFkUWDs=
118+
github.com/planetscale/planetscale-go v0.125.0/go.mod h1:/9cIDXvqglfjCRPzPNP6BklL+J7qq50SKtAP97c4ix0=
119119
github.com/planetscale/psdb v0.0.0-20240109164348-6848e728f6e7 h1:dxdoFKWVDlV1gq8UQC8NWCofLjCEjEHw47gfeojgs28=
120120
github.com/planetscale/psdb v0.0.0-20240109164348-6848e728f6e7/go.mod h1:WZmi4gw3rOK+ryd1inGxgfKwoFV04O7xBCqzWzv0/0U=
121121
github.com/planetscale/psdbproxy v0.0.0-20250117221522-0c8e2b0e36e6 h1:/Ox1ZTAdk+soSngzzKoJh5voOzptrpPrux11o30rIaw=
@@ -187,8 +187,8 @@ golang.org/x/net v0.0.0-20210226172049-e18ecbb05110/go.mod h1:m0MpNAwzfU5UDzcl9v
187187
golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c=
188188
golang.org/x/net v0.29.0 h1:5ORfpBpCs4HzDYoodCDBbwHzdR5UrLBZ3sOnUJmFoHo=
189189
golang.org/x/net v0.29.0/go.mod h1:gLkgy8jTGERgjzMic6DS9+SP0ajcu6Xu3Orq/SpETg0=
190-
golang.org/x/oauth2 v0.27.0 h1:da9Vo7/tDv5RH/7nZDz1eMGS/q1Vv1N/7FCrBhI9I3M=
191-
golang.org/x/oauth2 v0.27.0/go.mod h1:onh5ek6nERTohokkhCD/y2cV4Do3fxFHFuAejCkRWT8=
190+
golang.org/x/oauth2 v0.28.0 h1:CrgCKl8PPAVtLnU3c+EDw6x11699EWlsDeWNWKdIOkc=
191+
golang.org/x/oauth2 v0.28.0/go.mod h1:onh5ek6nERTohokkhCD/y2cV4Do3fxFHFuAejCkRWT8=
192192
golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
193193
golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
194194
golang.org/x/sync v0.11.0 h1:GGz8+XQP4FvTTrjZPzNKTMFtSXH80RAzG+5ghFPgK9w=

internal/cmd/database/create.go

+1-1
Original file line numberDiff line numberDiff line change
@@ -27,7 +27,7 @@ func CreateCmd(ch *cmdutil.Helper) *cobra.Command {
2727
return err
2828
}
2929

30-
createReq.ClusterSize = ps.ClusterSize(clusterSize)
30+
createReq.ClusterSize = clusterSize
3131

3232
createReq.Organization = ch.Config.Organization
3333
createReq.Name = args[0]

internal/cmd/keyspace/create.go

+1-1
Original file line numberDiff line numberDiff line change
@@ -33,7 +33,7 @@ func CreateCmd(ch *cmdutil.Helper) *cobra.Command {
3333
createReq.Name = keyspace
3434
createReq.Shards = flags.shards
3535
createReq.ExtraReplicas = flags.additionalReplicas
36-
createReq.ClusterSize = planetscale.ClusterSize(flags.clusterSize)
36+
createReq.ClusterSize = flags.clusterSize
3737

3838
client, err := ch.Client()
3939
if err != nil {

internal/cmd/keyspace/create_test.go

+4-4
Original file line numberDiff line numberDiff line change
@@ -30,7 +30,7 @@ func TestKeyspace_CreateCmd(t *testing.T) {
3030
ks := &ps.Keyspace{
3131
ID: "wantid",
3232
Name: keyspace,
33-
ClusterSize: ps.ClusterSize("PS-20"),
33+
ClusterSize: "PS-20",
3434
Replicas: 3,
3535
Shards: 2,
3636
}
@@ -41,7 +41,7 @@ func TestKeyspace_CreateCmd(t *testing.T) {
4141
c.Assert(req.Organization, qt.Equals, org)
4242
c.Assert(req.Branch, qt.Equals, branch)
4343
c.Assert(req.Name, qt.Equals, keyspace)
44-
c.Assert(req.ClusterSize, qt.Equals, ps.ClusterSize("PS-20"))
44+
c.Assert(req.ClusterSize, qt.Equals, "PS-20")
4545
c.Assert(req.ExtraReplicas, qt.Equals, 1)
4646
c.Assert(req.Shards, qt.Equals, 2)
4747

@@ -86,7 +86,7 @@ func TestKeyspace_CreateCmdOnlyClusterSize(t *testing.T) {
8686
ks := &ps.Keyspace{
8787
ID: "wantid",
8888
Name: keyspace,
89-
ClusterSize: ps.ClusterSize("PS-10"),
89+
ClusterSize: "PS-10",
9090
Replicas: 2,
9191
ExtraReplicas: 0,
9292
Shards: 1,
@@ -98,7 +98,7 @@ func TestKeyspace_CreateCmdOnlyClusterSize(t *testing.T) {
9898
c.Assert(req.Organization, qt.Equals, org)
9999
c.Assert(req.Branch, qt.Equals, branch)
100100
c.Assert(req.Name, qt.Equals, keyspace)
101-
c.Assert(req.ClusterSize, qt.Equals, ps.ClusterSize("PS-10"))
101+
c.Assert(req.ClusterSize, qt.Equals, "PS-10")
102102
c.Assert(req.ExtraReplicas, qt.Equals, 0)
103103
c.Assert(req.Shards, qt.Equals, 1)
104104

internal/cmd/keyspace/resize.go

+1-1
Original file line numberDiff line numberDiff line change
@@ -56,7 +56,7 @@ func ResizeCmd(ch *cmdutil.Helper) *cobra.Command {
5656
}
5757

5858
if cmd.Flags().Changed("cluster-size") {
59-
size := ps.ClusterSize(flags.clusterSize)
59+
size := flags.clusterSize
6060
resizeReq.ClusterSize = &size
6161
}
6262

internal/cmd/keyspace/resize_test.go

+2-2
Original file line numberDiff line numberDiff line change
@@ -45,7 +45,7 @@ func TestKeyspace_ResizeCmd(t *testing.T) {
4545
c.Assert(req.Branch, qt.Equals, branch)
4646
c.Assert(req.Keyspace, qt.Equals, keyspace)
4747
c.Assert(*req.ExtraReplicas, qt.Equals, uint(3))
48-
c.Assert(*req.ClusterSize, qt.Equals, ps.ClusterSize("PS_10"))
48+
c.Assert(*req.ClusterSize, qt.Equals, "PS_10")
4949

5050
return krr, nil
5151
},
@@ -102,7 +102,7 @@ func TestKeyspace_ResizeCmdOnlyClusterSize(t *testing.T) {
102102
c.Assert(req.Branch, qt.Equals, branch)
103103
c.Assert(req.Keyspace, qt.Equals, keyspace)
104104
c.Assert(req.ExtraReplicas, qt.IsNil)
105-
c.Assert(*req.ClusterSize, qt.Equals, ps.ClusterSize("PS_10"))
105+
c.Assert(*req.ClusterSize, qt.Equals, "PS_10")
106106

107107
return krr, nil
108108
},

internal/cmd/size/cluster.go

+11-3
Original file line numberDiff line numberDiff line change
@@ -26,6 +26,7 @@ func ClusterCmd(ch *cmdutil.Helper) *cobra.Command {
2626
func ListCmd(ch *cmdutil.Helper) *cobra.Command {
2727
var flags struct {
2828
region string
29+
metal bool
2930
}
3031

3132
cmd := &cobra.Command{
@@ -47,11 +48,12 @@ func ListCmd(ch *cmdutil.Helper) *cobra.Command {
4748
return err
4849
}
4950

50-
return ch.Printer.PrintResource(toClusterSKUs(clusterSKUs))
51+
return ch.Printer.PrintResource(toClusterSKUs(clusterSKUs, flags.metal))
5152
},
5253
}
5354

5455
cmd.Flags().StringVar(&flags.region, "region", "", "view cluster sizes and rates for a specific region")
56+
cmd.Flags().BoolVar(&flags.metal, "metal", false, "view cluster sizes and rates for clusters with metal storage")
5557

5658
cmd.RegisterFlagCompletionFunc("region", func(cmd *cobra.Command, args []string, toComplete string) ([]cobra.Completion, cobra.ShellCompDirective) {
5759
return cmdutil.RegionsCompletionFunc(ch, cmd, args, toComplete)
@@ -103,12 +105,18 @@ func toClusterSKU(clusterSKU *planetscale.ClusterSKU) *ClusterSKU {
103105
return cluster
104106
}
105107

106-
func toClusterSKUs(clusterSKUs []*planetscale.ClusterSKU) []*ClusterSKU {
108+
func toClusterSKUs(clusterSKUs []*planetscale.ClusterSKU, onlyMetal bool) []*ClusterSKU {
107109
clusters := make([]*ClusterSKU, 0, len(clusterSKUs))
108110

109111
for _, clusterSKU := range clusterSKUs {
110112
if clusterSKU.Enabled && clusterSKU.Rate != nil && clusterSKU.Name != "PS_DEV" {
111-
clusters = append(clusters, toClusterSKU(clusterSKU))
113+
if onlyMetal {
114+
if clusterSKU.Metal {
115+
clusters = append(clusters, toClusterSKU(clusterSKU))
116+
}
117+
} else {
118+
clusters = append(clusters, toClusterSKU(clusterSKU))
119+
}
112120
}
113121
}
114122

internal/cmdutil/cmdutil.go

+2-2
Original file line numberDiff line numberDiff line change
@@ -296,8 +296,8 @@ func DeployRequestBranchToNumber(ctx context.Context, client *ps.Client, organiz
296296
return deployRequests[0].Number, nil
297297
}
298298

299-
func ToClusterSizeSlug(c ps.ClusterSize) string {
300-
return strings.ReplaceAll(string(c), "_", "-")
299+
func ToClusterSizeSlug(c string) string {
300+
return strings.ReplaceAll(c, "_", "-")
301301
}
302302

303303
func SnakeToSentenceCase(s string) string {

0 commit comments

Comments
 (0)