mirror of
				https://github.com/minio/minio.git
				synced 2025-11-04 02:01:05 +01:00 
			
		
		
		
	This change uses the updated ldap library in minio/pkg (bumped up to v3). A new config parameter is added for LDAP configuration to specify extra user attributes to load from the LDAP server and to store them as additional claims for the user. A test is added in sts_handlers.go that shows how to access the LDAP attributes as a claim. This is in preparation for adding SSH pubkey authentication to MinIO's SFTP integration.
		
			
				
	
	
		
			101 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			101 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright (c) 2015-2022 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 callhome
 | 
						|
 | 
						|
import (
 | 
						|
	"sync"
 | 
						|
	"time"
 | 
						|
 | 
						|
	"github.com/minio/minio/internal/config"
 | 
						|
	"github.com/minio/pkg/v3/env"
 | 
						|
)
 | 
						|
 | 
						|
// Callhome related keys
 | 
						|
const (
 | 
						|
	Enable    = "enable"
 | 
						|
	Frequency = "frequency"
 | 
						|
)
 | 
						|
 | 
						|
// DefaultKVS - default KV config for subnet settings
 | 
						|
var DefaultKVS = config.KVS{
 | 
						|
	config.KV{
 | 
						|
		Key:   Enable,
 | 
						|
		Value: "off",
 | 
						|
	},
 | 
						|
	config.KV{
 | 
						|
		Key:   Frequency,
 | 
						|
		Value: "24h",
 | 
						|
	},
 | 
						|
}
 | 
						|
 | 
						|
// callhomeCycleDefault is the default interval between two callhome cycles (24hrs)
 | 
						|
const callhomeCycleDefault = 24 * time.Hour
 | 
						|
 | 
						|
// Config represents the subnet related configuration
 | 
						|
type Config struct {
 | 
						|
	// Flag indicating whether callhome is enabled.
 | 
						|
	Enable bool `json:"enable"`
 | 
						|
 | 
						|
	// The interval between callhome cycles
 | 
						|
	Frequency time.Duration `json:"frequency"`
 | 
						|
}
 | 
						|
 | 
						|
var configLock sync.RWMutex
 | 
						|
 | 
						|
// Enabled - indicates if callhome is enabled or not
 | 
						|
func (c *Config) Enabled() bool {
 | 
						|
	configLock.RLock()
 | 
						|
	defer configLock.RUnlock()
 | 
						|
 | 
						|
	return c.Enable
 | 
						|
}
 | 
						|
 | 
						|
// FrequencyDur - returns the currently configured callhome frequency
 | 
						|
func (c *Config) FrequencyDur() time.Duration {
 | 
						|
	configLock.RLock()
 | 
						|
	defer configLock.RUnlock()
 | 
						|
 | 
						|
	if c.Frequency == 0 {
 | 
						|
		return callhomeCycleDefault
 | 
						|
	}
 | 
						|
 | 
						|
	return c.Frequency
 | 
						|
}
 | 
						|
 | 
						|
// Update updates new callhome frequency
 | 
						|
func (c *Config) Update(ncfg Config) {
 | 
						|
	configLock.Lock()
 | 
						|
	defer configLock.Unlock()
 | 
						|
 | 
						|
	c.Enable = ncfg.Enable
 | 
						|
	c.Frequency = ncfg.Frequency
 | 
						|
}
 | 
						|
 | 
						|
// LookupConfig - lookup config and override with valid environment settings if any.
 | 
						|
func LookupConfig(kvs config.KVS) (cfg Config, err error) {
 | 
						|
	if err = config.CheckValidKeys(config.CallhomeSubSys, kvs, DefaultKVS); err != nil {
 | 
						|
		return cfg, err
 | 
						|
	}
 | 
						|
 | 
						|
	cfg.Enable = env.Get(config.EnvMinIOCallhomeEnable,
 | 
						|
		kvs.GetWithDefault(Enable, DefaultKVS)) == config.EnableOn
 | 
						|
	cfg.Frequency, err = time.ParseDuration(env.Get(config.EnvMinIOCallhomeFrequency,
 | 
						|
		kvs.GetWithDefault(Frequency, DefaultKVS)))
 | 
						|
	return cfg, err
 | 
						|
}
 |