Commit c1fdb6f1 authored by Roger Peppe's avatar Roger Peppe Committed by Russ Cox

goinstall: protect against malicious filenames.

It was possible to make package run arbitrary
commands when installing if its filenames contained
make metacharacters.

R=rsc, niemeyer
CC=golang-dev
https://golang.org/cl/4248041
parent 49a4d7dc
...@@ -44,6 +44,9 @@ func domake(dir, pkg string, local bool) (err os.Error) { ...@@ -44,6 +44,9 @@ func domake(dir, pkg string, local bool) (err os.Error) {
// installing as package pkg. It includes all *.go files in the directory // installing as package pkg. It includes all *.go files in the directory
// except those in package main and those ending in _test.go. // except those in package main and those ending in _test.go.
func makeMakefile(dir, pkg string) ([]byte, os.Error) { func makeMakefile(dir, pkg string) ([]byte, os.Error) {
if !safeName(pkg) {
return nil, os.ErrorString("unsafe name: " + pkg)
}
dirInfo, err := scanDir(dir, false) dirInfo, err := scanDir(dir, false)
if err != nil { if err != nil {
return nil, err return nil, err
...@@ -58,16 +61,25 @@ func makeMakefile(dir, pkg string) ([]byte, os.Error) { ...@@ -58,16 +61,25 @@ func makeMakefile(dir, pkg string) ([]byte, os.Error) {
cgoFiles := dirInfo.cgoFiles cgoFiles := dirInfo.cgoFiles
isCgo := make(map[string]bool, len(cgoFiles)) isCgo := make(map[string]bool, len(cgoFiles))
for _, file := range cgoFiles { for _, file := range cgoFiles {
if !safeName(file) {
return nil, os.ErrorString("bad name: " + file)
}
isCgo[file] = true isCgo[file] = true
} }
oFiles := make([]string, 0, len(dirInfo.cFiles)) oFiles := make([]string, 0, len(dirInfo.cFiles))
for _, file := range dirInfo.cFiles { for _, file := range dirInfo.cFiles {
if !safeName(file) {
return nil, os.ErrorString("unsafe name: " + file)
}
oFiles = append(oFiles, file[:len(file)-2]+".o") oFiles = append(oFiles, file[:len(file)-2]+".o")
} }
goFiles := make([]string, 0, len(dirInfo.goFiles)) goFiles := make([]string, 0, len(dirInfo.goFiles))
for _, file := range dirInfo.goFiles { for _, file := range dirInfo.goFiles {
if !safeName(file) {
return nil, os.ErrorString("unsafe name: " + file)
}
if !isCgo[file] { if !isCgo[file] {
goFiles = append(goFiles, file) goFiles = append(goFiles, file)
} }
...@@ -81,6 +93,17 @@ func makeMakefile(dir, pkg string) ([]byte, os.Error) { ...@@ -81,6 +93,17 @@ func makeMakefile(dir, pkg string) ([]byte, os.Error) {
return buf.Bytes(), nil return buf.Bytes(), nil
} }
var safeBytes = []byte("+-./0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ_abcdefghijklmnopqrstuvwxyz")
func safeName(s string) bool {
for i := 0; i < len(s); i++ {
if c := s[i]; c < 0x80 && bytes.IndexByte(safeBytes, c) < 0 {
return false
}
}
return true
}
// makedata is the data type for the makefileTemplate. // makedata is the data type for the makefileTemplate.
type makedata struct { type makedata struct {
Pkg string // package import path Pkg string // package import path
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment