mirror of
https://github.com/minio/minio.git
synced 2025-01-11 23:13:23 -05:00
5f78691fcf
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.
169 lines
5.0 KiB
Go
169 lines
5.0 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 compress
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
|
|
"github.com/minio/minio/internal/config"
|
|
"github.com/minio/pkg/v3/env"
|
|
)
|
|
|
|
// Config represents the compression settings.
|
|
type Config struct {
|
|
Enabled bool `json:"enabled"`
|
|
AllowEncrypted bool `json:"allow_encryption"`
|
|
Extensions []string `json:"extensions"`
|
|
MimeTypes []string `json:"mime-types"`
|
|
}
|
|
|
|
// Compression environment variables
|
|
const (
|
|
Extensions = "extensions"
|
|
AllowEncrypted = "allow_encryption"
|
|
MimeTypes = "mime_types"
|
|
|
|
EnvCompressState = "MINIO_COMPRESSION_ENABLE"
|
|
EnvCompressAllowEncryption = "MINIO_COMPRESSION_ALLOW_ENCRYPTION"
|
|
EnvCompressExtensions = "MINIO_COMPRESSION_EXTENSIONS"
|
|
EnvCompressMimeTypes = "MINIO_COMPRESSION_MIME_TYPES"
|
|
|
|
// Include-list for compression.
|
|
DefaultExtensions = ".txt,.log,.csv,.json,.tar,.xml,.bin"
|
|
DefaultMimeTypes = "text/*,application/json,application/xml,binary/octet-stream"
|
|
)
|
|
|
|
// DefaultKVS - default KV config for compression settings
|
|
var (
|
|
DefaultKVS = config.KVS{
|
|
config.KV{
|
|
Key: config.Enable,
|
|
Value: config.EnableOff,
|
|
},
|
|
config.KV{
|
|
Key: AllowEncrypted,
|
|
Value: config.EnableOff,
|
|
},
|
|
config.KV{
|
|
Key: Extensions,
|
|
Value: DefaultExtensions,
|
|
},
|
|
config.KV{
|
|
Key: MimeTypes,
|
|
Value: DefaultMimeTypes,
|
|
},
|
|
}
|
|
)
|
|
|
|
// Parses the given compression exclude list `extensions` or `content-types`.
|
|
func parseCompressIncludes(include string) ([]string, error) {
|
|
includes := strings.Split(include, config.ValueSeparator)
|
|
for _, e := range includes {
|
|
if len(e) == 0 {
|
|
return nil, config.ErrInvalidCompressionIncludesValue(nil).Msg("extension/mime-type cannot be empty")
|
|
}
|
|
if e == "/" {
|
|
return nil, config.ErrInvalidCompressionIncludesValue(nil).Msg("extension/mime-type cannot be '/'")
|
|
}
|
|
}
|
|
return includes, nil
|
|
}
|
|
|
|
// LookupConfig - lookup compression config.
|
|
func LookupConfig(kvs config.KVS) (Config, error) {
|
|
var err error
|
|
cfg := Config{}
|
|
if err = config.CheckValidKeys(config.CompressionSubSys, kvs, DefaultKVS); err != nil {
|
|
return cfg, err
|
|
}
|
|
|
|
compress := env.Get(EnvCompressState, kvs.Get(config.Enable))
|
|
if compress == "" {
|
|
compress = env.Get(EnvCompress, "")
|
|
}
|
|
cfg.Enabled, err = config.ParseBool(compress)
|
|
if err != nil {
|
|
// Parsing failures happen due to empty KVS, ignore it.
|
|
if kvs.Empty() {
|
|
return cfg, nil
|
|
}
|
|
return cfg, err
|
|
}
|
|
if !cfg.Enabled {
|
|
return cfg, nil
|
|
}
|
|
|
|
allowEnc := env.Get(EnvCompressAllowEncryption, kvs.Get(AllowEncrypted))
|
|
if allowEnc == "" {
|
|
allowEnc = env.Get(EnvCompressAllowEncryptionLegacy, "")
|
|
}
|
|
|
|
cfg.AllowEncrypted, err = config.ParseBool(allowEnc)
|
|
if err != nil {
|
|
return cfg, err
|
|
}
|
|
|
|
compressExtensions := env.Get(EnvCompressExtensions, kvs.Get(Extensions))
|
|
compressExtensionsLegacy := env.Get(EnvCompressExtensionsLegacy, "")
|
|
compressMimeTypes := env.Get(EnvCompressMimeTypes, kvs.Get(MimeTypes))
|
|
compressMimeTypesLegacy1 := env.Get(EnvCompressMimeTypesLegacy1, "")
|
|
compressMimeTypesLegacy2 := env.Get(EnvCompressMimeTypesLegacy2, "")
|
|
if compressExtensions != "" {
|
|
extensions, err := parseCompressIncludes(compressExtensions)
|
|
if err != nil {
|
|
return cfg, fmt.Errorf("%s: Invalid MINIO_COMPRESSION_EXTENSIONS value (`%s`)", err, extensions)
|
|
}
|
|
cfg.Extensions = extensions
|
|
}
|
|
|
|
if compressExtensionsLegacy != "" {
|
|
extensions, err := parseCompressIncludes(compressExtensions)
|
|
if err != nil {
|
|
return cfg, fmt.Errorf("%s: Invalid MINIO_COMPRESS_EXTENSIONS value (`%s`)", err, extensions)
|
|
}
|
|
cfg.Extensions = extensions
|
|
}
|
|
|
|
if compressMimeTypes != "" {
|
|
mimeTypes, err := parseCompressIncludes(compressMimeTypes)
|
|
if err != nil {
|
|
return cfg, fmt.Errorf("%s: Invalid MINIO_COMPRESSION_MIME_TYPES value (`%s`)", err, mimeTypes)
|
|
}
|
|
cfg.MimeTypes = mimeTypes
|
|
}
|
|
|
|
if compressMimeTypesLegacy1 != "" {
|
|
mimeTypes, err := parseCompressIncludes(compressMimeTypesLegacy1)
|
|
if err != nil {
|
|
return cfg, fmt.Errorf("%s: Invalid MINIO_COMPRESS_MIMETYPES value (`%s`)", err, mimeTypes)
|
|
}
|
|
cfg.MimeTypes = mimeTypes
|
|
}
|
|
|
|
if compressMimeTypesLegacy2 != "" {
|
|
mimeTypes, err := parseCompressIncludes(compressMimeTypesLegacy2)
|
|
if err != nil {
|
|
return cfg, fmt.Errorf("%s: Invalid MINIO_COMPRESS_MIME_TYPES value (`%s`)", err, mimeTypes)
|
|
}
|
|
cfg.MimeTypes = mimeTypes
|
|
}
|
|
|
|
return cfg, nil
|
|
}
|