mirror of
				https://github.com/fluxcd/flux2.git
				synced 2025-10-31 08:17:19 +08:00 
			
		
		
		
	 5ea4e814f5
			
		
	
	5ea4e814f5
	
	
	
		
			
			This commit adds multiple safe guards for relative paths, ensuring they never traverse outside the working directory. The `SafeRelativePath` flag calculates the safe relative path based on a relative base dir, which results in a flattened path. The write methods of `manifestgen` make use of the `SecureJoin` as well, to ensure writes are never outside of the given directory when used as a lib outside of the CLI. Signed-off-by: Hidde Beydals <hello@hidde.co>
		
			
				
	
	
		
			50 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| /*
 | |
| Copyright 2020 The Flux authors
 | |
| 
 | |
| Licensed under the Apache License, Version 2.0 (the "License");
 | |
| you may not use this file except in compliance with the License.
 | |
| You may obtain a copy of the License at
 | |
| 
 | |
|     http://www.apache.org/licenses/LICENSE-2.0
 | |
| 
 | |
| Unless required by applicable law or agreed to in writing, software
 | |
| distributed under the License is distributed on an "AS IS" BASIS,
 | |
| WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| See the License for the specific language governing permissions and
 | |
| limitations under the License.
 | |
| */
 | |
| 
 | |
| package flags
 | |
| 
 | |
| import (
 | |
| 	"testing"
 | |
| )
 | |
| 
 | |
| func TestRelativePath_Set(t *testing.T) {
 | |
| 	tests := []struct {
 | |
| 		name      string
 | |
| 		str       string
 | |
| 		expect    string
 | |
| 		expectErr bool
 | |
| 	}{
 | |
| 		{"relative path", "./foo", "./foo", false},
 | |
| 		{"relative path", "foo", "./foo", false},
 | |
| 		{"traversing relative path", "./foo/../bar", "./bar", false},
 | |
| 		{"absolute path", "/foo", "./foo", false},
 | |
| 		{"traversing absolute path", "/foo/../bar", "./bar", false},
 | |
| 		{"traversing overflowing absolute path", "/foo/../../../bar", "./bar", false},
 | |
| 		{"empty", "", "./", false},
 | |
| 	}
 | |
| 	for _, tt := range tests {
 | |
| 		t.Run(tt.name, func(t *testing.T) {
 | |
| 			var p SafeRelativePath
 | |
| 			if err := p.Set(tt.str); (err != nil) != tt.expectErr {
 | |
| 				t.Errorf("Set() error = %v, expectErr %v", err, tt.expectErr)
 | |
| 			}
 | |
| 			if str := p.String(); str != tt.expect {
 | |
| 				t.Errorf("Set() = %v, expect %v", str, tt.expect)
 | |
| 			}
 | |
| 		})
 | |
| 	}
 | |
| }
 |