From 4af6f6d8ab2cc31f59891a24fe1c01795b0a2b68 Mon Sep 17 00:00:00 2001 From: lu4p Date: Sun, 14 Jun 2020 00:38:08 +0200 Subject: [PATCH] fix broken -seed=random + remove unused spec --- crypto.go | 3 ++- main.go | 24 +++++++++++++++--------- strings.go | 14 -------------- testdata/scripts/seed.txt | 26 ++++++++++++++++++-------- 4 files changed, 35 insertions(+), 32 deletions(-) diff --git a/crypto.go b/crypto.go index 7e0054b..d6923ea 100644 --- a/crypto.go +++ b/crypto.go @@ -6,6 +6,7 @@ import ( "crypto/rand" "fmt" mathrand "math/rand" + "strings" ) // If math/rand.Seed() is not called, the generator behaves as if seeded by rand.Seed(1), @@ -25,7 +26,7 @@ func genNonce() []byte { func genRandBytes(size int) []byte { buffer := make([]byte, size) - if envGarbleSeed == "random" { + if strings.HasPrefix(envGarbleSeed, "random;") { _, err := rand.Read(buffer) if err != nil { panic(fmt.Sprintf("couldn't generate random key: %v", err)) diff --git a/main.go b/main.go index b49f435..94baf3b 100644 --- a/main.go +++ b/main.go @@ -195,6 +195,17 @@ func mainErr(args []string) error { } os.Setenv("GARBLE_DIR", wd) os.Setenv("GARBLE_LITERALS", fmt.Sprint(flagGarbleLiterals)) + + if flagSeed == "random" { + seed = make([]byte, 16) // random 128 bit seed + + _, err = rand.Read(seed) + if err != nil { + return fmt.Errorf("Error generating random seed: %v", err) + } + + flagSeed = "random;" + base64.StdEncoding.EncodeToString(seed) + } os.Setenv("GARBLE_SEED", flagSeed) if flagDebugDir != "" { @@ -349,20 +360,15 @@ func transformCompile(args []string) ([]string, error) { files = append(files, file) } - if envGarbleSeed == "random" { - seed = make([]byte, 16) // random 128 bit seed - - _, err = rand.Read(seed) - if err != nil { - return nil, fmt.Errorf("Error generating random seed: %v", err) - } - } else if envGarbleSeed != "" { - seed, err = base64.StdEncoding.DecodeString(envGarbleSeed) + if envGarbleSeed != "" { + seed, err = base64.StdEncoding.DecodeString(strings.TrimPrefix(envGarbleSeed, "random;")) if err != nil { return nil, fmt.Errorf("Error decoding base64 encoded seed: %v", err) } mathrand.Seed(int64(binary.BigEndian.Uint64(seed))) + } else { + mathrand.Seed(int64(binary.BigEndian.Uint64([]byte(buildInfo.buildID)))) } if envGarbleLiterals { diff --git a/strings.go b/strings.go index 05cbb27..33a7c32 100644 --- a/strings.go +++ b/strings.go @@ -240,17 +240,3 @@ func keyStmt(key []byte) *ast.GenDecl { }}, } } - -var cryptoAesImportSpec = &ast.GenDecl{ - Tok: token.IMPORT, - Specs: []ast.Spec{ - &ast.ImportSpec{Path: &ast.BasicLit{ - Kind: token.STRING, - Value: `"crypto/aes"`, - }}, - &ast.ImportSpec{Path: &ast.BasicLit{ - Kind: token.STRING, - Value: `"crypto/cipher"`, - }}, - }, -} diff --git a/testdata/scripts/seed.txt b/testdata/scripts/seed.txt index 4b77399..6751804 100644 --- a/testdata/scripts/seed.txt +++ b/testdata/scripts/seed.txt @@ -1,43 +1,53 @@ # Check the binary with a given base64 encoded seed -garble -literals -seed=OQg9kACEECQ= build main.go +garble -literals -seed=OQg9kACEECQ= build exec ./main$exe cmp stderr main.stdout -! binsubstr main$exe 'teststring' 'teststringVar' +! binsubstr main$exe 'teststring' 'teststringVar' 'imported var value' 'ImportedVar' [short] stop # checking that the build is reproducible and random is slow # Also check that the binary is reproducible. cp main$exe main_old$exe rm main$exe -garble -literals -seed=OQg9kACEECQ= build main.go +garble -literals -seed=OQg9kACEECQ= build bincmp main$exe main_old$exe # Also check that a different seed leads to a different binary cp main$exe main_old$exe rm main$exe -garble -literals -seed=NruiDmVz6/s= build main.go +garble -literals -seed=NruiDmVz6/s= build ! bincmp main$exe main_old$exe # Check the random binary -garble -literals -seed=random build main.go +garble -literals -seed=random build exec ./main$exe cmp stderr main.stdout -! binsubstr main$exe 'teststring' 'teststringVar' +! binsubstr main$exe 'teststring' 'teststringVar' 'imported var value' 'ImportedVar' # Also check that the random binary is not reproducible. cp main$exe main_old$exe rm main$exe -garble -literals -seed=random build main.go +garble -literals -seed=random build ! bincmp main$exe main_old$exe +-- go.mod -- +module test/main -- main.go -- package main +import "test/main/imported" + var teststringVar = "teststring" func main() { println(teststringVar) + println(imported.ImportedVar) } +-- imported/imported.go -- +package imported + +var ImportedVar = "imported var value" -- main.stdout -- -teststring \ No newline at end of file +teststring +imported var value \ No newline at end of file