From d032c0bd1089059fbeba1c5cf3baf2c3a572ace7 Mon Sep 17 00:00:00 2001 From: Pagran <67878280+pagran@users.noreply.github.com> Date: Fri, 11 Sep 2020 16:16:24 +0300 Subject: [PATCH] Fixes and extend private name charset --- import_obfuscation.go | 2 ++ main.go | 48 ++++++++++++++++++++++++++++++------------- 2 files changed, 36 insertions(+), 14 deletions(-) diff --git a/import_obfuscation.go b/import_obfuscation.go index 91a584b..b6590c4 100644 --- a/import_obfuscation.go +++ b/import_obfuscation.go @@ -55,6 +55,8 @@ func appendPrivateNameMap(nameMap map[string]string, packageDirectory string) er if err != nil { return err } + defer file.Close() + if err := json.NewDecoder(file).Decode(&nameMap); err != nil { return err } diff --git a/main.go b/main.go index b3ac254..9454234 100644 --- a/main.go +++ b/main.go @@ -19,6 +19,8 @@ import ( "go/printer" "go/token" "go/types" + "golang.org/x/mod/module" + "golang.org/x/tools/go/ast/astutil" "io" "io/ioutil" "log" @@ -28,9 +30,7 @@ import ( "path/filepath" "runtime" "strings" - - "golang.org/x/mod/module" - "golang.org/x/tools/go/ast/astutil" + "unicode" "mvdan.cc/garble/internal/literals" ) @@ -110,10 +110,10 @@ var ( envGarbleListPkgs = os.Getenv("GARBLE_LISTPKGS") seed []byte - - garbleMapFile = "garble.map" ) +const garbleMapFile = "garble.map" + func saveListedPackages(w io.Writer, flags, patterns []string) error { args := []string{"list", "-json", "-deps", "-export"} args = append(args, flags...) @@ -729,14 +729,33 @@ func hashWith(salt, value string) string { return "z" + sum[:length] } +func buildNameCharset() []rune { + var charset []rune + + for _, r := range unicode.Letter.R16 { + for c := r.Lo; c <= r.Hi; c += r.Stride { + charset = append(charset, rune(c)) + } + } + + for _, r := range unicode.Digit.R16 { + for c := r.Lo; c <= r.Hi; c += r.Stride { + charset = append(charset, rune(c)) + } + } + + return charset +} + +var privateNameCharset = buildNameCharset() + func encodeIntToName(i int) string { - const privateNameCharset = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789_" builder := strings.Builder{} builder.WriteByte('_') for i > 0 { charIdx := i % len(privateNameCharset) i -= charIdx + 1 - builder.WriteByte(privateNameCharset[charIdx]) + builder.WriteRune(privateNameCharset[charIdx]) } return builder.String() } @@ -806,7 +825,7 @@ func buildBlacklist(files []*ast.File, info *types.Info, pkg *types.Package) map } // transformGo garbles the provided Go syntax node. -func transformGo(file *ast.File, info *types.Info, blacklist map[types.Object]struct{}, nameMap map[string]string, pkgPath string) *ast.File { +func transformGo(file *ast.File, info *types.Info, blacklist map[types.Object]struct{}, privateNameMap map[string]string, pkgPath string) *ast.File { // Shuffle top level declarations mathrand.Shuffle(len(file.Decls), func(i, j int) { decl1 := file.Decls[i] @@ -917,22 +936,22 @@ func transformGo(file *ast.File, info *types.Info, blacklist map[types.Object]st buildID = id } - // Exported names cannot be shortened because it is impossible to synchronize the counter between packages + // The exported names cannot be shortened as counter synchronization between packages is not currently implemented if token.IsExported(node.Name) { node.Name = hashWith(buildID, node.Name) return true } fullName := pkgPath + "." + node.Name - if name, ok := nameMap[fullName]; ok { + if name, ok := privateNameMap[fullName]; ok { node.Name = name return true } - name := encodeIntToName(len(nameMap) + 1) + name := encodeIntToName(len(privateNameMap) + 1) // orig := node.Name - nameMap[fullName] = name + privateNameMap[fullName] = name node.Name = name // log.Printf("%q hashed with %q to %q", orig, buildID, node.Name) return true @@ -993,7 +1012,7 @@ func transformLink(args []string) ([]string, error) { importCfgPath := flagValue(flags, "-importcfg") // there should only ever be one archive/object file passed to the linker, // the file for the main package or entrypoint - garbledImports, nameMap, err := obfuscateImports(paths[0], importCfgPath) + garbledImports, privateNameMap, err := obfuscateImports(paths[0], importCfgPath) if err != nil { return nil, err } @@ -1022,7 +1041,8 @@ func transformLink(args []string) ([]string, error) { pkgPath = buildInfo.firstImport } if id := buildInfo.imports[pkgPath].buildID; id != "" { - newName, ok := nameMap[pkg+"."+name] + // If the name is not in the map file, it means that the name was not obfuscated or is public + newName, ok := privateNameMap[pkg+"."+name] if !ok { newName = hashWith(id, name) }