• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

supabase / cli / 18717582655

22 Oct 2025 01:20PM UTC coverage: 54.587% (-0.02%) from 54.604%
18717582655

Pull #4334

github

web-flow
Merge 92d4874c5 into 8d34a0f7e
Pull Request #4334: feat: command to analyze table read/write I/O patterns

14 of 24 new or added lines in 2 files covered. (58.33%)

5 existing lines in 1 file now uncovered.

6403 of 11730 relevant lines covered (54.59%)

6.11 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

12.9
/internal/gen/keys/keys.go
1
package keys
2

3
import (
4
        "context"
5
        "crypto/sha256"
6
        "encoding/hex"
7
        "fmt"
8
        "os"
9
        "strings"
10

11
        "github.com/go-errors/errors"
12
        "github.com/go-git/go-git/v5"
13
        "github.com/spf13/afero"
14
        "github.com/supabase/cli/internal/utils"
15
        "github.com/supabase/cli/pkg/config"
16
)
17

18
type CustomName struct {
19
        DbHost         string `env:"db.host,default=NEXT_PUBLIC_SUPABASE_URL"`
20
        DbPassword     string `env:"db.password,default=SUPABASE_DB_PASSWORD"`
21
        JWTSecret      string `env:"db.password,default=SUPABASE_AUTH_JWT_SECRET"`
22
        AnonKey        string `env:"auth.anon_key,default=SUPABASE_AUTH_ANON_KEY"`
23
        ServiceRoleKey string `env:"auth.service_role_key,default=SUPABASE_AUTH_SERVICE_ROLE_KEY"`
24
}
25

26
func Run(ctx context.Context, projectRef, format string, names CustomName, fsys afero.Fs) error {
×
27
        branch := GetGitBranch(fsys)
×
28
        if err := GenerateSecrets(ctx, projectRef, branch, fsys); err != nil {
×
29
                return err
×
30
        }
×
31
        return utils.EncodeOutput(format, os.Stdout, map[string]string{
×
32
                names.DbHost:         fmt.Sprintf("%s-%s.fly.dev", projectRef, branch),
×
33
                names.DbPassword:     utils.Config.Db.Password,
×
34
                names.JWTSecret:      utils.Config.Auth.JwtSecret.Value,
×
35
                names.AnonKey:        utils.Config.Auth.AnonKey.Value,
×
36
                names.ServiceRoleKey: utils.Config.Auth.ServiceRoleKey.Value,
×
37
        })
×
38
}
39

40
func GenerateSecrets(ctx context.Context, projectRef, branch string, fsys afero.Fs) error {
×
41
        // Load JWT secret from api
×
42
        resp, err := utils.GetSupabase().V1GetPostgrestServiceConfigWithResponse(ctx, projectRef)
×
43
        if err != nil {
×
44
                return errors.Errorf("failed to get postgrest config: %w", err)
×
45
        }
×
46
        if resp.JSON200 == nil {
×
47
                return errors.New("Unexpected error retrieving JWT secret: " + string(resp.Body))
×
48
        }
×
49
        utils.Config.Auth.JwtSecret.Value = *resp.JSON200.JwtSecret
×
50
        // Generate database password
×
51
        key := strings.Join([]string{
×
52
                projectRef,
×
53
                utils.Config.Auth.JwtSecret.Value,
×
54
                branch,
×
55
        }, ":")
×
56
        hash := sha256.Sum256([]byte(key))
×
57
        utils.Config.Db.Password = hex.EncodeToString(hash[:])
×
58
        // Generate JWT tokens
×
59
        anonToken := config.CustomClaims{
×
60
                Issuer: "supabase",
×
61
                Ref:    projectRef,
×
62
                Role:   "anon",
×
63
        }.NewToken()
×
64
        if utils.Config.Auth.AnonKey.Value, err = anonToken.SignedString([]byte(utils.Config.Auth.JwtSecret.Value)); err != nil {
×
65
                return errors.Errorf("failed to sign anon key: %w", err)
×
66
        }
×
67
        serviceToken := config.CustomClaims{
×
68
                Issuer: "supabase",
×
69
                Ref:    projectRef,
×
70
                Role:   "service_role",
×
71
        }.NewToken()
×
72
        if utils.Config.Auth.ServiceRoleKey.Value, err = serviceToken.SignedString([]byte(utils.Config.Auth.JwtSecret.Value)); err != nil {
×
73
                return errors.Errorf("failed to sign service_role key: %w", err)
×
74
        }
×
75
        return nil
×
76
}
77

78
func GetGitBranch(fsys afero.Fs) string {
2✔
79
        return GetGitBranchOrDefault("main", fsys)
2✔
80
}
2✔
81

82
func GetGitBranchOrDefault(def string, fsys afero.Fs) string {
5✔
83
        head := os.Getenv("GITHUB_HEAD_REF")
5✔
84
        if len(head) > 0 {
10✔
85
                return head
5✔
86
        }
5✔
UNCOV
87
        opts := &git.PlainOpenOptions{DetectDotGit: true}
×
UNCOV
88
        if repo, err := git.PlainOpenWithOptions(".", opts); err == nil {
×
UNCOV
89
                if ref, err := repo.Head(); err == nil {
×
UNCOV
90
                        return ref.Name().Short()
×
UNCOV
91
                }
×
92
        }
93
        return def
×
94
}
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2025 Coveralls, Inc