mirror of
				https://github.com/minio/minio.git
				synced 2025-10-26 05:41:53 +01:00 
			
		
		
		
	This change adds a `Secret` property to `HelpKV` to identify secrets like passwords and auth tokens that should not be revealed by the server in its configuration fetching APIs. Configuration reporting APIs now do not return secrets.
		
			
				
	
	
		
			103 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			103 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright (c) 2015-2021 MinIO, Inc.
 | |
| //
 | |
| // This file is part of MinIO Object Storage stack
 | |
| //
 | |
| // This program is free software: you can redistribute it and/or modify
 | |
| // it under the terms of the GNU Affero General Public License as published by
 | |
| // the Free Software Foundation, either version 3 of the License, or
 | |
| // (at your option) any later version.
 | |
| //
 | |
| // This program is distributed in the hope that it will be useful
 | |
| // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
| // GNU Affero General Public License for more details.
 | |
| //
 | |
| // You should have received a copy of the GNU Affero General Public License
 | |
| // along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | |
| 
 | |
| package config
 | |
| 
 | |
| // HelpKV - implements help messages for keys
 | |
| // with value as description of the keys.
 | |
| type HelpKV struct {
 | |
| 	Key         string `json:"key"`
 | |
| 	Type        string `json:"type"`
 | |
| 	Description string `json:"description"`
 | |
| 	Optional    bool   `json:"optional"`
 | |
| 
 | |
| 	// Indicates if the value contains sensitive info that shouldn't be exposed
 | |
| 	// in certain apis (such as Health Diagnostics/Callhome)
 | |
| 	Sensitive bool `json:"-"`
 | |
| 
 | |
| 	// Indicates if the value is a secret such as a password that shouldn't be
 | |
| 	// exposed by the server
 | |
| 	Secret bool `json:"-"`
 | |
| 
 | |
| 	// Indicates if sub-sys supports multiple targets.
 | |
| 	MultipleTargets bool `json:"multipleTargets"`
 | |
| }
 | |
| 
 | |
| // HelpKVS - implement order of keys help messages.
 | |
| type HelpKVS []HelpKV
 | |
| 
 | |
| // Lookup - lookup a key from help kvs.
 | |
| func (hkvs HelpKVS) Lookup(key string) (HelpKV, bool) {
 | |
| 	for _, hkv := range hkvs {
 | |
| 		if hkv.Key == key {
 | |
| 			return hkv, true
 | |
| 		}
 | |
| 	}
 | |
| 	return HelpKV{}, false
 | |
| }
 | |
| 
 | |
| // DefaultComment used across all sub-systems.
 | |
| const DefaultComment = "optionally add a comment to this setting"
 | |
| 
 | |
| // Region help is documented in default config
 | |
| var (
 | |
| 	SiteHelp = HelpKVS{
 | |
| 		HelpKV{
 | |
| 			Key:         NameKey,
 | |
| 			Type:        "string",
 | |
| 			Description: `name for the site e.g. "cal-rack0"`,
 | |
| 			Optional:    true,
 | |
| 		},
 | |
| 		HelpKV{
 | |
| 			Key:         RegionKey,
 | |
| 			Type:        "string",
 | |
| 			Description: `name of the location of the server e.g. "us-west-1"`,
 | |
| 			Optional:    true,
 | |
| 		},
 | |
| 		HelpKV{
 | |
| 			Key:         Comment,
 | |
| 			Type:        "sentence",
 | |
| 			Description: DefaultComment,
 | |
| 			Optional:    true,
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	RegionHelp = HelpKVS{
 | |
| 		HelpKV{
 | |
| 			Key:         RegionName,
 | |
| 			Type:        "string",
 | |
| 			Description: `[DEPRECATED] name of the location of the server e.g. "us-west-rack2"`,
 | |
| 			Optional:    true,
 | |
| 		},
 | |
| 		HelpKV{
 | |
| 			Key:         Comment,
 | |
| 			Type:        "sentence",
 | |
| 			Description: DefaultComment,
 | |
| 			Optional:    true,
 | |
| 		},
 | |
| 	}
 | |
| )
 | |
| 
 | |
| // DefaultHelpPostfix - Helper function to add (default: $value) messages in config help
 | |
| func DefaultHelpPostfix(subsystem KVS, key string) string {
 | |
| 	val, found := subsystem.Lookup(key)
 | |
| 	if !found || val == "" {
 | |
| 		return ""
 | |
| 	}
 | |
| 	return " (default: '" + val + "')"
 | |
| }
 |