letsencrypt: Fix perm of user key

This commit is contained in:
Xidorn Quan 2016-01-16 12:36:40 +11:00
parent 8655ea671b
commit 0d8d0ba5a0
2 changed files with 16 additions and 1 deletions

View file

@ -25,6 +25,7 @@ func saveRSAPrivateKey(key *rsa.PrivateKey, file string) error {
if err != nil { if err != nil {
return err return err
} }
keyOut.Chmod(0600)
defer keyOut.Close() defer keyOut.Close()
return pem.Encode(keyOut, &pemKey) return pem.Encode(keyOut, &pemKey)
} }

View file

@ -6,6 +6,7 @@ import (
"crypto/rsa" "crypto/rsa"
"crypto/x509" "crypto/x509"
"os" "os"
"runtime"
"testing" "testing"
) )
@ -28,13 +29,26 @@ func TestSaveAndLoadRSAPrivateKey(t *testing.T) {
t.Fatal("error saving private key:", err) t.Fatal("error saving private key:", err)
} }
// it doesn't make sense to test file permission on windows
if runtime.GOOS != "windows" {
// get info of the key file
info, err := os.Stat(keyFile)
if err != nil {
t.Fatal("error stating private key:", err)
}
// verify permission of key file is correct
if info.Mode().Perm() != 0600 {
t.Error("Expected key file to have permission 0600, but it wasn't")
}
}
// test load // test load
loadedKey, err := loadRSAPrivateKey(keyFile) loadedKey, err := loadRSAPrivateKey(keyFile)
if err != nil { if err != nil {
t.Error("error loading private key:", err) t.Error("error loading private key:", err)
} }
// very loaded key is correct // verify loaded key is correct
if !rsaPrivateKeysSame(privateKey, loadedKey) { if !rsaPrivateKeysSame(privateKey, loadedKey) {
t.Error("Expected key bytes to be the same, but they weren't") t.Error("Expected key bytes to be the same, but they weren't")
} }