2016-07-12 23:21:18 -07:00
|
|
|
/*
|
2019-04-09 11:39:42 -07:00
|
|
|
* MinIO Cloud Storage, (C) 2016, 2017, 2018 MinIO, Inc.
|
2016-07-12 23:21:18 -07:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2016-08-18 16:23:42 -07:00
|
|
|
package cmd
|
2016-07-12 23:21:18 -07:00
|
|
|
|
|
|
|
import (
|
2016-10-14 13:48:08 +02:00
|
|
|
"crypto/x509"
|
2016-07-12 23:21:18 -07:00
|
|
|
"fmt"
|
2018-12-18 08:26:30 -08:00
|
|
|
"net"
|
2016-07-12 23:21:18 -07:00
|
|
|
"runtime"
|
|
|
|
"strings"
|
|
|
|
|
2016-10-05 12:48:07 -07:00
|
|
|
humanize "github.com/dustin/go-humanize"
|
2020-03-17 15:25:00 -07:00
|
|
|
"github.com/minio/minio/cmd/logger"
|
2019-10-04 10:35:33 -07:00
|
|
|
color "github.com/minio/minio/pkg/color"
|
2018-12-13 23:37:46 -08:00
|
|
|
xnet "github.com/minio/minio/pkg/net"
|
2016-07-12 23:21:18 -07:00
|
|
|
)
|
|
|
|
|
|
|
|
// Documentation links, these are part of message printing code.
|
|
|
|
const (
|
2019-11-09 09:27:23 -08:00
|
|
|
mcQuickStartGuide = "https://docs.min.io/docs/minio-client-quickstart-guide"
|
|
|
|
mcAdminQuickStartGuide = "https://docs.min.io/docs/minio-admin-complete-guide.html"
|
|
|
|
goQuickStartGuide = "https://docs.min.io/docs/golang-client-quickstart-guide"
|
|
|
|
jsQuickStartGuide = "https://docs.min.io/docs/javascript-client-quickstart-guide"
|
|
|
|
javaQuickStartGuide = "https://docs.min.io/docs/java-client-quickstart-guide"
|
|
|
|
pyQuickStartGuide = "https://docs.min.io/docs/python-client-quickstart-guide"
|
|
|
|
dotnetQuickStartGuide = "https://docs.min.io/docs/dotnet-client-quickstart-guide"
|
2016-07-12 23:21:18 -07:00
|
|
|
)
|
|
|
|
|
|
|
|
// generates format string depending on the string length and padding.
|
|
|
|
func getFormatStr(strLen int, padding int) string {
|
|
|
|
formatStr := fmt.Sprintf("%ds", strLen+padding)
|
|
|
|
return "%" + formatStr
|
|
|
|
}
|
|
|
|
|
2019-11-09 09:27:23 -08:00
|
|
|
func printStartupSafeModeMessage(apiEndpoints []string, err error) {
|
|
|
|
logStartupMessage(color.RedBold("Server startup failed with '%v'", err))
|
|
|
|
logStartupMessage(color.RedBold("Server switching to safe mode"))
|
2019-12-04 15:32:37 -08:00
|
|
|
logStartupMessage(color.RedBold("Please use 'mc admin config' commands fix this issue"))
|
2019-11-09 09:27:23 -08:00
|
|
|
|
|
|
|
// Object layer is initialized then print StorageInfo in safe mode.
|
|
|
|
objAPI := newObjectLayerWithoutSafeModeFn()
|
|
|
|
if objAPI != nil {
|
2020-04-09 09:30:02 -07:00
|
|
|
if msg := getStorageInfoMsgSafeMode(objAPI.StorageInfo(GlobalContext, false)); msg != "" {
|
2019-11-09 09:27:23 -08:00
|
|
|
logStartupMessage(msg)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get saved credentials.
|
|
|
|
cred := globalActiveCred
|
|
|
|
|
|
|
|
// Get saved region.
|
|
|
|
region := globalServerRegion
|
|
|
|
|
|
|
|
strippedAPIEndpoints := stripStandardPorts(apiEndpoints)
|
|
|
|
|
|
|
|
apiEndpointStr := strings.Join(strippedAPIEndpoints, " ")
|
|
|
|
|
|
|
|
// Colorize the message and print.
|
|
|
|
logStartupMessage(color.Red("Endpoint: ") + color.Bold(fmt.Sprintf(getFormatStr(len(apiEndpointStr), 1), apiEndpointStr)))
|
|
|
|
if color.IsTerminal() && !globalCLIContext.Anonymous {
|
|
|
|
logStartupMessage(color.Red("AccessKey: ") + color.Bold(fmt.Sprintf("%s ", cred.AccessKey)))
|
|
|
|
logStartupMessage(color.Red("SecretKey: ") + color.Bold(fmt.Sprintf("%s ", cred.SecretKey)))
|
|
|
|
if region != "" {
|
|
|
|
logStartupMessage(color.Red("Region: ") + color.Bold(fmt.Sprintf(getFormatStr(len(region), 3), region)))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Prints `mc` cli configuration message chooses
|
|
|
|
// first endpoint as default.
|
|
|
|
alias := "myminio"
|
|
|
|
endPoint := strippedAPIEndpoints[0]
|
|
|
|
|
|
|
|
// Configure 'mc', following block prints platform specific information for minio client admin commands.
|
2020-01-06 08:42:47 -08:00
|
|
|
if color.IsTerminal() && !globalCLIContext.Anonymous {
|
2019-11-09 09:27:23 -08:00
|
|
|
logStartupMessage(color.RedBold("\nCommand-line Access: ") + mcAdminQuickStartGuide)
|
|
|
|
if runtime.GOOS == globalWindowsOSName {
|
|
|
|
mcMessage := fmt.Sprintf("> mc.exe config host add %s %s %s %s --api s3v4", alias,
|
|
|
|
endPoint, cred.AccessKey, cred.SecretKey)
|
|
|
|
logStartupMessage(fmt.Sprintf(getFormatStr(len(mcMessage), 3), mcMessage))
|
2020-03-19 00:19:29 +01:00
|
|
|
mcMessage = "> mc.exe admin config --help"
|
2019-11-09 09:27:23 -08:00
|
|
|
logStartupMessage(fmt.Sprintf(getFormatStr(len(mcMessage), 3), mcMessage))
|
|
|
|
} else {
|
|
|
|
mcMessage := fmt.Sprintf("$ mc config host add %s %s %s %s --api s3v4", alias,
|
|
|
|
endPoint, cred.AccessKey, cred.SecretKey)
|
|
|
|
logStartupMessage(fmt.Sprintf(getFormatStr(len(mcMessage), 3), mcMessage))
|
2020-03-19 00:19:29 +01:00
|
|
|
mcMessage = "$ mc admin config --help"
|
2019-11-09 09:27:23 -08:00
|
|
|
logStartupMessage(fmt.Sprintf(getFormatStr(len(mcMessage), 3), mcMessage))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-07-12 23:21:18 -07:00
|
|
|
// Prints the formatted startup message.
|
2019-11-09 09:27:23 -08:00
|
|
|
func printStartupMessage(apiEndpoints []string) {
|
2017-04-12 09:22:35 -07:00
|
|
|
|
2019-11-09 09:27:23 -08:00
|
|
|
strippedAPIEndpoints := stripStandardPorts(apiEndpoints)
|
2018-03-28 14:14:06 -07:00
|
|
|
// If cache layer is enabled, print cache capacity.
|
2019-11-09 09:27:23 -08:00
|
|
|
cachedObjAPI := newCachedObjectLayerFn()
|
|
|
|
if cachedObjAPI != nil {
|
2020-04-09 09:30:02 -07:00
|
|
|
printCacheStorageInfo(cachedObjAPI.StorageInfo(GlobalContext))
|
2018-03-28 14:14:06 -07:00
|
|
|
}
|
2019-11-09 09:27:23 -08:00
|
|
|
|
2017-12-22 16:58:13 +05:30
|
|
|
// Object layer is initialized then print StorageInfo.
|
2019-11-09 09:27:23 -08:00
|
|
|
objAPI := newObjectLayerFn()
|
2017-12-22 16:58:13 +05:30
|
|
|
if objAPI != nil {
|
2020-04-09 09:30:02 -07:00
|
|
|
printStorageInfo(objAPI.StorageInfo(GlobalContext, false))
|
2017-12-22 16:58:13 +05:30
|
|
|
}
|
|
|
|
|
2017-01-10 16:43:48 -08:00
|
|
|
// Prints credential, region and browser access.
|
2017-05-31 09:21:28 -07:00
|
|
|
printServerCommonMsg(strippedAPIEndpoints)
|
2017-01-10 16:43:48 -08:00
|
|
|
|
|
|
|
// Prints `mc` cli configuration message chooses
|
|
|
|
// first endpoint as default.
|
2017-06-09 19:50:51 -07:00
|
|
|
printCLIAccessMsg(strippedAPIEndpoints[0], "myminio")
|
2017-01-10 16:43:48 -08:00
|
|
|
|
|
|
|
// Prints documentation message.
|
2016-07-12 23:21:18 -07:00
|
|
|
printObjectAPIMsg()
|
2016-10-14 13:48:08 +02:00
|
|
|
|
2017-01-10 16:43:48 -08:00
|
|
|
// SSL is configured reads certification chain, prints
|
|
|
|
// authority and expiry.
|
2017-01-11 13:59:51 -08:00
|
|
|
if globalIsSSL {
|
2017-03-30 23:51:19 +05:30
|
|
|
printCertificateMsg(globalPublicCerts)
|
2016-10-14 13:48:08 +02:00
|
|
|
}
|
2016-07-12 23:21:18 -07:00
|
|
|
}
|
|
|
|
|
2018-12-18 08:26:30 -08:00
|
|
|
// Returns true if input is not IPv4, false if it is.
|
|
|
|
func isNotIPv4(host string) bool {
|
|
|
|
h, _, err := net.SplitHostPort(host)
|
|
|
|
if err != nil {
|
|
|
|
h = host
|
|
|
|
}
|
|
|
|
ip := net.ParseIP(h)
|
|
|
|
ok := ip.To4() != nil // This is always true of IP is IPv4
|
|
|
|
|
|
|
|
// Returns true if input is not IPv4.
|
|
|
|
return !ok
|
|
|
|
}
|
|
|
|
|
2017-05-31 09:21:28 -07:00
|
|
|
// strip api endpoints list with standard ports such as
|
|
|
|
// port "80" and "443" before displaying on the startup
|
|
|
|
// banner. Returns a new list of API endpoints.
|
|
|
|
func stripStandardPorts(apiEndpoints []string) (newAPIEndpoints []string) {
|
|
|
|
newAPIEndpoints = make([]string, len(apiEndpoints))
|
|
|
|
// Check all API endpoints for standard ports and strip them.
|
|
|
|
for i, apiEndpoint := range apiEndpoints {
|
2019-10-30 23:39:09 -07:00
|
|
|
u, err := xnet.ParseHTTPURL(apiEndpoint)
|
2017-05-31 09:21:28 -07:00
|
|
|
if err != nil {
|
|
|
|
continue
|
|
|
|
}
|
2018-12-18 08:26:30 -08:00
|
|
|
if globalMinioHost == "" && isNotIPv4(u.Host) {
|
|
|
|
// Skip all non-IPv4 endpoints when we bind to all interfaces.
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
newAPIEndpoints[i] = u.String()
|
2017-05-31 09:21:28 -07:00
|
|
|
}
|
|
|
|
return newAPIEndpoints
|
|
|
|
}
|
|
|
|
|
2016-07-12 23:21:18 -07:00
|
|
|
// Prints common server startup message. Prints credential, region and browser access.
|
2017-01-10 16:43:48 -08:00
|
|
|
func printServerCommonMsg(apiEndpoints []string) {
|
2016-07-12 23:21:18 -07:00
|
|
|
// Get saved credentials.
|
2019-10-22 22:59:13 -07:00
|
|
|
cred := globalActiveCred
|
2016-07-12 23:21:18 -07:00
|
|
|
|
|
|
|
// Get saved region.
|
2019-10-22 22:59:13 -07:00
|
|
|
region := globalServerRegion
|
2016-07-12 23:21:18 -07:00
|
|
|
|
2017-01-10 16:43:48 -08:00
|
|
|
apiEndpointStr := strings.Join(apiEndpoints, " ")
|
2017-05-31 09:21:28 -07:00
|
|
|
|
2016-07-12 23:21:18 -07:00
|
|
|
// Colorize the message and print.
|
2019-10-04 10:35:33 -07:00
|
|
|
logStartupMessage(color.Blue("Endpoint: ") + color.Bold(fmt.Sprintf(getFormatStr(len(apiEndpointStr), 1), apiEndpointStr)))
|
|
|
|
if color.IsTerminal() && !globalCLIContext.Anonymous {
|
|
|
|
logStartupMessage(color.Blue("AccessKey: ") + color.Bold(fmt.Sprintf("%s ", cred.AccessKey)))
|
|
|
|
logStartupMessage(color.Blue("SecretKey: ") + color.Bold(fmt.Sprintf("%s ", cred.SecretKey)))
|
2018-10-16 13:19:12 -07:00
|
|
|
if region != "" {
|
2019-10-04 10:35:33 -07:00
|
|
|
logStartupMessage(color.Blue("Region: ") + color.Bold(fmt.Sprintf(getFormatStr(len(region), 3), region)))
|
2018-10-16 13:19:12 -07:00
|
|
|
}
|
2017-05-15 18:17:02 -07:00
|
|
|
}
|
2016-09-14 01:11:03 -07:00
|
|
|
printEventNotifiers()
|
2016-09-13 23:30:40 +05:30
|
|
|
|
2019-10-22 22:59:13 -07:00
|
|
|
if globalBrowserEnabled {
|
2019-10-04 10:35:33 -07:00
|
|
|
logStartupMessage(color.Blue("\nBrowser Access:"))
|
2019-09-22 01:24:32 -07:00
|
|
|
logStartupMessage(fmt.Sprintf(getFormatStr(len(apiEndpointStr), 3), apiEndpointStr))
|
2018-01-03 21:30:52 -08:00
|
|
|
}
|
2016-09-13 23:30:40 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
// Prints bucket notification configurations.
|
|
|
|
func printEventNotifiers() {
|
2019-11-13 17:38:05 -08:00
|
|
|
if globalNotificationSys == nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2018-03-16 01:33:41 +05:30
|
|
|
arns := globalNotificationSys.GetARNList()
|
|
|
|
if len(arns) == 0 {
|
2017-05-15 18:17:02 -07:00
|
|
|
return
|
2016-09-13 23:30:40 +05:30
|
|
|
}
|
2018-03-16 01:33:41 +05:30
|
|
|
|
2019-10-04 10:35:33 -07:00
|
|
|
arnMsg := color.Blue("SQS ARNs: ")
|
2018-03-16 01:33:41 +05:30
|
|
|
for _, arn := range arns {
|
2019-10-04 10:35:33 -07:00
|
|
|
arnMsg += color.Bold(fmt.Sprintf(getFormatStr(len(arn), 1), arn))
|
2016-09-10 02:23:28 -07:00
|
|
|
}
|
2018-03-16 01:33:41 +05:30
|
|
|
|
2019-09-22 01:24:32 -07:00
|
|
|
logStartupMessage(arnMsg)
|
2016-07-12 23:21:18 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// Prints startup message for command line access. Prints link to our documentation
|
|
|
|
// and custom platform specific message.
|
2017-06-09 19:50:51 -07:00
|
|
|
func printCLIAccessMsg(endPoint string, alias string) {
|
2016-07-12 23:21:18 -07:00
|
|
|
// Get saved credentials.
|
2019-10-22 22:59:13 -07:00
|
|
|
cred := globalActiveCred
|
2016-07-12 23:21:18 -07:00
|
|
|
|
|
|
|
// Configure 'mc', following block prints platform specific information for minio client.
|
2020-01-06 08:42:47 -08:00
|
|
|
if color.IsTerminal() && !globalCLIContext.Anonymous {
|
2019-10-04 10:35:33 -07:00
|
|
|
logStartupMessage(color.Blue("\nCommand-line Access: ") + mcQuickStartGuide)
|
2018-10-16 13:19:12 -07:00
|
|
|
if runtime.GOOS == globalWindowsOSName {
|
2019-10-04 10:35:33 -07:00
|
|
|
mcMessage := fmt.Sprintf("$ mc.exe config host add %s %s %s %s", alias,
|
|
|
|
endPoint, cred.AccessKey, cred.SecretKey)
|
2019-09-22 01:24:32 -07:00
|
|
|
logStartupMessage(fmt.Sprintf(getFormatStr(len(mcMessage), 3), mcMessage))
|
2018-10-16 13:19:12 -07:00
|
|
|
} else {
|
2019-10-04 10:35:33 -07:00
|
|
|
mcMessage := fmt.Sprintf("$ mc config host add %s %s %s %s", alias,
|
|
|
|
endPoint, cred.AccessKey, cred.SecretKey)
|
2019-09-22 01:24:32 -07:00
|
|
|
logStartupMessage(fmt.Sprintf(getFormatStr(len(mcMessage), 3), mcMessage))
|
2018-10-16 13:19:12 -07:00
|
|
|
}
|
2016-07-12 23:21:18 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Prints startup message for Object API acces, prints link to our SDK documentation.
|
|
|
|
func printObjectAPIMsg() {
|
2019-10-04 10:35:33 -07:00
|
|
|
logStartupMessage(color.Blue("\nObject API (Amazon S3 compatible):"))
|
|
|
|
logStartupMessage(color.Blue(" Go: ") + fmt.Sprintf(getFormatStr(len(goQuickStartGuide), 8), goQuickStartGuide))
|
|
|
|
logStartupMessage(color.Blue(" Java: ") + fmt.Sprintf(getFormatStr(len(javaQuickStartGuide), 6), javaQuickStartGuide))
|
|
|
|
logStartupMessage(color.Blue(" Python: ") + fmt.Sprintf(getFormatStr(len(pyQuickStartGuide), 4), pyQuickStartGuide))
|
|
|
|
logStartupMessage(color.Blue(" JavaScript: ") + jsQuickStartGuide)
|
|
|
|
logStartupMessage(color.Blue(" .NET: ") + fmt.Sprintf(getFormatStr(len(dotnetQuickStartGuide), 6), dotnetQuickStartGuide))
|
2016-07-12 23:21:18 -07:00
|
|
|
}
|
2016-10-05 12:48:07 -07:00
|
|
|
|
2019-11-09 09:27:23 -08:00
|
|
|
// Get formatted disk/storage info message.
|
|
|
|
func getStorageInfoMsgSafeMode(storageInfo StorageInfo) string {
|
|
|
|
var msg string
|
2020-03-17 15:25:00 -07:00
|
|
|
var mcMessage string
|
2019-11-09 09:27:23 -08:00
|
|
|
if storageInfo.Backend.Type == BackendErasure {
|
2020-03-17 15:25:00 -07:00
|
|
|
if storageInfo.Backend.OfflineDisks.Sum() > 0 {
|
2020-03-21 10:02:20 -07:00
|
|
|
mcMessage = "Use `mc admin info` to look for latest server/disk info`"
|
2020-03-17 15:25:00 -07:00
|
|
|
}
|
2020-03-21 10:02:20 -07:00
|
|
|
diskInfo := fmt.Sprintf(" %d Online, %d Offline. ", storageInfo.Backend.OnlineDisks.Sum(), storageInfo.Backend.OfflineDisks.Sum())
|
2019-11-09 09:27:23 -08:00
|
|
|
msg += color.Red("Status:") + fmt.Sprintf(getFormatStr(len(diskInfo), 8), diskInfo)
|
|
|
|
}
|
2020-03-21 10:02:20 -07:00
|
|
|
if len(mcMessage) > 0 {
|
|
|
|
msg = fmt.Sprintf("%s %s", mcMessage, msg)
|
|
|
|
}
|
2019-11-09 09:27:23 -08:00
|
|
|
return msg
|
|
|
|
}
|
|
|
|
|
2016-10-05 12:48:07 -07:00
|
|
|
// Get formatted disk/storage info message.
|
2016-10-09 23:03:10 -07:00
|
|
|
func getStorageInfoMsg(storageInfo StorageInfo) string {
|
2018-05-23 17:30:25 -07:00
|
|
|
var msg string
|
2020-03-17 15:25:00 -07:00
|
|
|
var mcMessage string
|
2018-08-23 23:35:37 -07:00
|
|
|
if storageInfo.Backend.Type == BackendErasure {
|
2020-03-17 15:25:00 -07:00
|
|
|
if storageInfo.Backend.OfflineDisks.Sum() > 0 {
|
2020-03-21 10:02:20 -07:00
|
|
|
mcMessage = "Use `mc admin info` to look for latest server/disk info"
|
2020-03-17 15:25:00 -07:00
|
|
|
}
|
2020-03-21 10:02:20 -07:00
|
|
|
|
|
|
|
diskInfo := fmt.Sprintf(" %d Online, %d Offline. ", storageInfo.Backend.OnlineDisks.Sum(), storageInfo.Backend.OfflineDisks.Sum())
|
2019-10-04 10:35:33 -07:00
|
|
|
msg += color.Blue("Status:") + fmt.Sprintf(getFormatStr(len(diskInfo), 8), diskInfo)
|
2020-03-21 10:02:20 -07:00
|
|
|
if len(mcMessage) > 0 {
|
|
|
|
msg = fmt.Sprintf("%s %s", mcMessage, msg)
|
|
|
|
}
|
2016-10-05 12:48:07 -07:00
|
|
|
}
|
|
|
|
return msg
|
|
|
|
}
|
|
|
|
|
|
|
|
// Prints startup message of storage capacity and erasure information.
|
2016-10-09 23:03:10 -07:00
|
|
|
func printStorageInfo(storageInfo StorageInfo) {
|
2018-05-23 17:30:25 -07:00
|
|
|
if msg := getStorageInfoMsg(storageInfo); msg != "" {
|
2020-03-17 15:25:00 -07:00
|
|
|
if globalCLIContext.Quiet {
|
|
|
|
logger.Info(msg)
|
|
|
|
}
|
2019-09-22 01:24:32 -07:00
|
|
|
logStartupMessage(msg)
|
2018-05-23 17:30:25 -07:00
|
|
|
}
|
2016-10-05 12:48:07 -07:00
|
|
|
}
|
2016-10-14 13:48:08 +02:00
|
|
|
|
2018-05-30 11:30:14 -07:00
|
|
|
func printCacheStorageInfo(storageInfo CacheStorageInfo) {
|
2019-10-04 10:35:33 -07:00
|
|
|
msg := fmt.Sprintf("%s %s Free, %s Total", color.Blue("Cache Capacity:"),
|
2018-03-28 14:14:06 -07:00
|
|
|
humanize.IBytes(uint64(storageInfo.Free)),
|
|
|
|
humanize.IBytes(uint64(storageInfo.Total)))
|
2019-09-22 01:24:32 -07:00
|
|
|
logStartupMessage(msg)
|
2018-03-28 14:14:06 -07:00
|
|
|
}
|
|
|
|
|
2016-10-14 13:48:08 +02:00
|
|
|
// Prints certificate expiry date warning
|
|
|
|
func getCertificateChainMsg(certs []*x509.Certificate) string {
|
2019-10-04 10:35:33 -07:00
|
|
|
msg := color.Blue("\nCertificate expiry info:\n")
|
2016-10-14 13:48:08 +02:00
|
|
|
totalCerts := len(certs)
|
|
|
|
var expiringCerts int
|
|
|
|
for i := totalCerts - 1; i >= 0; i-- {
|
|
|
|
cert := certs[i]
|
2017-03-18 23:58:41 +05:30
|
|
|
if cert.NotAfter.Before(UTCNow().Add(globalMinioCertExpireWarnDays)) {
|
2016-10-14 13:48:08 +02:00
|
|
|
expiringCerts++
|
2019-10-04 10:35:33 -07:00
|
|
|
msg += fmt.Sprintf(color.Bold("#%d %s will expire on %s\n"), expiringCerts, cert.Subject.CommonName, cert.NotAfter)
|
2016-10-14 13:48:08 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if expiringCerts > 0 {
|
|
|
|
return msg
|
|
|
|
}
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
2016-10-14 11:15:59 -07:00
|
|
|
// Prints the certificate expiry message.
|
2016-10-14 13:48:08 +02:00
|
|
|
func printCertificateMsg(certs []*x509.Certificate) {
|
2019-09-22 01:24:32 -07:00
|
|
|
logStartupMessage(getCertificateChainMsg(certs))
|
2016-10-14 13:48:08 +02:00
|
|
|
}
|