2021-04-19 03:41:13 +08:00
|
|
|
// 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/>.
|
2016-07-13 14:21:18 +08:00
|
|
|
|
2016-08-19 07:23:42 +08:00
|
|
|
package cmd
|
2016-07-13 14:21:18 +08:00
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2018-12-19 00:26:30 +08:00
|
|
|
"net"
|
2021-08-06 06:01:19 +08:00
|
|
|
"net/url"
|
2016-07-13 14:21:18 +08:00
|
|
|
"strings"
|
|
|
|
|
2024-08-23 22:11:35 +08:00
|
|
|
xnet "github.com/minio/pkg/v3/net"
|
|
|
|
|
2023-10-02 21:39:47 +08:00
|
|
|
"github.com/minio/minio/internal/color"
|
2021-06-02 05:59:40 +08:00
|
|
|
"github.com/minio/minio/internal/logger"
|
2016-07-13 14:21:18 +08: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
|
|
|
|
}
|
|
|
|
|
|
|
|
// Prints the formatted startup message.
|
2020-10-10 00:59:52 +08:00
|
|
|
func printStartupMessage(apiEndpoints []string, err error) {
|
2024-07-13 04:51:54 +08:00
|
|
|
banner := strings.Repeat("-", len(MinioBannerName))
|
|
|
|
if globalIsDistErasure {
|
|
|
|
logger.Startup(color.Bold(banner))
|
|
|
|
}
|
|
|
|
logger.Startup(color.Bold(MinioBannerName))
|
2020-10-10 00:59:52 +08:00
|
|
|
if err != nil {
|
2022-03-04 05:21:16 +08:00
|
|
|
if globalConsoleSys != nil {
|
2023-05-09 12:20:31 +08:00
|
|
|
globalConsoleSys.Send(GlobalContext, fmt.Sprintf("Server startup failed with '%v', some features may be missing", err))
|
2022-03-04 05:21:16 +08:00
|
|
|
}
|
2020-10-10 00:59:52 +08:00
|
|
|
}
|
2017-04-13 00:22:35 +08:00
|
|
|
|
2022-10-27 15:20:01 +08:00
|
|
|
if !globalSubnetConfig.Registered() {
|
2022-06-29 07:37:40 +08:00
|
|
|
var builder strings.Builder
|
|
|
|
startupBanner(&builder)
|
2024-07-13 04:51:54 +08:00
|
|
|
logger.Startup(builder.String())
|
2022-06-27 18:58:25 +08:00
|
|
|
}
|
|
|
|
|
2021-06-21 14:04:47 +08:00
|
|
|
strippedAPIEndpoints := stripStandardPorts(apiEndpoints, globalMinioHost)
|
2019-11-10 01:27:23 +08:00
|
|
|
|
2017-01-11 08:43:48 +08:00
|
|
|
// Prints credential, region and browser access.
|
2017-06-01 00:21:28 +08:00
|
|
|
printServerCommonMsg(strippedAPIEndpoints)
|
2017-01-11 08:43:48 +08:00
|
|
|
|
|
|
|
// Prints `mc` cli configuration message chooses
|
|
|
|
// first endpoint as default.
|
2017-06-10 10:50:51 +08:00
|
|
|
printCLIAccessMsg(strippedAPIEndpoints[0], "myminio")
|
2017-01-11 08:43:48 +08:00
|
|
|
|
|
|
|
// Prints documentation message.
|
2016-07-13 14:21:18 +08:00
|
|
|
printObjectAPIMsg()
|
2024-07-13 04:51:54 +08:00
|
|
|
if globalIsDistErasure {
|
|
|
|
logger.Startup(color.Bold(banner))
|
|
|
|
}
|
2016-07-13 14:21:18 +08:00
|
|
|
}
|
|
|
|
|
2021-08-06 06:01:19 +08:00
|
|
|
// Returns true if input is IPv6
|
|
|
|
func isIPv6(host string) bool {
|
2018-12-19 00:26:30 +08:00
|
|
|
h, _, err := net.SplitHostPort(host)
|
|
|
|
if err != nil {
|
|
|
|
h = host
|
|
|
|
}
|
|
|
|
ip := net.ParseIP(h)
|
2021-08-06 06:01:19 +08:00
|
|
|
return ip.To16() != nil && ip.To4() == nil
|
2018-12-19 00:26:30 +08:00
|
|
|
}
|
|
|
|
|
2017-06-01 00:21:28 +08: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.
|
2021-06-21 14:04:47 +08:00
|
|
|
func stripStandardPorts(apiEndpoints []string, host string) (newAPIEndpoints []string) {
|
2021-08-06 06:01:19 +08:00
|
|
|
if len(apiEndpoints) == 1 {
|
|
|
|
return apiEndpoints
|
2021-07-24 06:22:25 +08:00
|
|
|
}
|
2017-06-01 00:21:28 +08:00
|
|
|
newAPIEndpoints = make([]string, len(apiEndpoints))
|
|
|
|
// Check all API endpoints for standard ports and strip them.
|
|
|
|
for i, apiEndpoint := range apiEndpoints {
|
2021-08-06 06:01:19 +08:00
|
|
|
_, err := xnet.ParseHTTPURL(apiEndpoint)
|
|
|
|
if err != nil {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
u, err := url.Parse(apiEndpoint)
|
2017-06-01 00:21:28 +08:00
|
|
|
if err != nil {
|
|
|
|
continue
|
|
|
|
}
|
2021-08-06 06:01:19 +08:00
|
|
|
if host == "" && isIPv6(u.Hostname()) {
|
|
|
|
// Skip all IPv6 endpoints
|
2018-12-19 00:26:30 +08:00
|
|
|
continue
|
|
|
|
}
|
2021-08-06 06:01:19 +08:00
|
|
|
if u.Port() == "80" && u.Scheme == "http" || u.Port() == "443" && u.Scheme == "https" {
|
|
|
|
u.Host = u.Hostname()
|
|
|
|
}
|
2018-12-19 00:26:30 +08:00
|
|
|
newAPIEndpoints[i] = u.String()
|
2017-06-01 00:21:28 +08:00
|
|
|
}
|
|
|
|
return newAPIEndpoints
|
|
|
|
}
|
|
|
|
|
2016-07-13 14:21:18 +08:00
|
|
|
// Prints common server startup message. Prints credential, region and browser access.
|
2017-01-11 08:43:48 +08:00
|
|
|
func printServerCommonMsg(apiEndpoints []string) {
|
2016-07-13 14:21:18 +08:00
|
|
|
// Get saved credentials.
|
2019-10-23 13:59:13 +08:00
|
|
|
cred := globalActiveCred
|
2016-07-13 14:21:18 +08:00
|
|
|
|
|
|
|
// Get saved region.
|
2024-05-17 07:13:47 +08:00
|
|
|
region := globalSite.Region()
|
2016-07-13 14:21:18 +08:00
|
|
|
|
2024-03-09 11:07:08 +08:00
|
|
|
apiEndpointStr := strings.TrimSpace(strings.Join(apiEndpoints, " "))
|
2016-07-13 14:21:18 +08:00
|
|
|
// Colorize the message and print.
|
2024-07-13 04:51:54 +08:00
|
|
|
logger.Startup(color.Blue("API: ") + color.Bold(fmt.Sprintf("%s ", apiEndpointStr)))
|
2024-03-02 05:09:42 +08:00
|
|
|
if color.IsTerminal() && (!globalServerCtxt.Anonymous && !globalServerCtxt.JSON && globalAPIConfig.permitRootAccess()) {
|
2024-07-13 04:51:54 +08:00
|
|
|
logger.Startup(color.Blue(" RootUser: ") + color.Bold("%s ", cred.AccessKey))
|
|
|
|
logger.Startup(color.Blue(" RootPass: ") + color.Bold("%s \n", cred.SecretKey))
|
2018-10-17 04:19:12 +08:00
|
|
|
if region != "" {
|
2024-07-13 04:51:54 +08:00
|
|
|
logger.Startup(color.Blue(" Region: ") + color.Bold("%s", fmt.Sprintf(getFormatStr(len(region), 2), region)))
|
2018-10-17 04:19:12 +08:00
|
|
|
}
|
2017-05-16 09:17:02 +08:00
|
|
|
}
|
2021-04-30 10:01:43 +08:00
|
|
|
|
|
|
|
if globalBrowserEnabled {
|
2021-06-21 14:04:47 +08:00
|
|
|
consoleEndpointStr := strings.Join(stripStandardPorts(getConsoleEndpoints(), globalMinioConsoleHost), " ")
|
2024-07-13 04:51:54 +08:00
|
|
|
logger.Startup(color.Blue("WebUI: ") + color.Bold(fmt.Sprintf("%s ", consoleEndpointStr)))
|
2024-03-02 05:09:42 +08:00
|
|
|
if color.IsTerminal() && (!globalServerCtxt.Anonymous && !globalServerCtxt.JSON && globalAPIConfig.permitRootAccess()) {
|
2024-07-13 04:51:54 +08:00
|
|
|
logger.Startup(color.Blue(" RootUser: ") + color.Bold("%s ", cred.AccessKey))
|
|
|
|
logger.Startup(color.Blue(" RootPass: ") + color.Bold("%s ", cred.SecretKey))
|
2021-06-18 11:27:04 +08:00
|
|
|
}
|
2021-04-30 10:01:43 +08:00
|
|
|
}
|
2023-04-15 22:34:02 +08:00
|
|
|
|
|
|
|
printEventNotifiers()
|
|
|
|
printLambdaTargets()
|
2016-09-14 02:00:40 +08:00
|
|
|
}
|
|
|
|
|
2022-09-29 12:28:45 +08:00
|
|
|
// Prints startup message for Object API access, prints link to our SDK documentation.
|
2021-06-18 11:27:04 +08:00
|
|
|
func printObjectAPIMsg() {
|
2024-08-23 22:11:35 +08:00
|
|
|
logger.Startup(color.Blue("\nDocs: ") + "https://docs.min.io")
|
2021-06-18 11:27:04 +08:00
|
|
|
}
|
|
|
|
|
2023-03-08 00:12:41 +08:00
|
|
|
func printLambdaTargets() {
|
|
|
|
if globalLambdaTargetList == nil || globalLambdaTargetList.Empty() {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
arnMsg := color.Blue("Object Lambda ARNs: ")
|
2024-05-17 07:13:47 +08:00
|
|
|
for _, arn := range globalLambdaTargetList.List(globalSite.Region()) {
|
2023-03-08 00:12:41 +08:00
|
|
|
arnMsg += color.Bold(fmt.Sprintf("%s ", arn))
|
|
|
|
}
|
2024-07-13 04:51:54 +08:00
|
|
|
logger.Startup(arnMsg + "\n")
|
2023-03-08 00:12:41 +08:00
|
|
|
}
|
|
|
|
|
2016-09-14 02:00:40 +08:00
|
|
|
// Prints bucket notification configurations.
|
|
|
|
func printEventNotifiers() {
|
2019-11-14 09:38:05 +08:00
|
|
|
if globalNotificationSys == nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-06-20 22:46:02 +08:00
|
|
|
arns := globalEventNotifier.GetARNList()
|
2018-03-16 04:03:41 +08:00
|
|
|
if len(arns) == 0 {
|
2017-05-16 09:17:02 +08:00
|
|
|
return
|
2016-09-14 02:00:40 +08:00
|
|
|
}
|
2018-03-16 04:03:41 +08:00
|
|
|
|
2019-10-05 01:35:33 +08:00
|
|
|
arnMsg := color.Blue("SQS ARNs: ")
|
2018-03-16 04:03:41 +08:00
|
|
|
for _, arn := range arns {
|
2021-01-07 02:38:07 +08:00
|
|
|
arnMsg += color.Bold(fmt.Sprintf("%s ", arn))
|
2016-09-10 17:23:28 +08:00
|
|
|
}
|
2018-03-16 04:03:41 +08:00
|
|
|
|
2024-07-13 04:51:54 +08:00
|
|
|
logger.Startup(arnMsg + "\n")
|
2016-07-13 14:21:18 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// Prints startup message for command line access. Prints link to our documentation
|
|
|
|
// and custom platform specific message.
|
2017-06-10 10:50:51 +08:00
|
|
|
func printCLIAccessMsg(endPoint string, alias string) {
|
2016-07-13 14:21:18 +08:00
|
|
|
// Get saved credentials.
|
2019-10-23 13:59:13 +08:00
|
|
|
cred := globalActiveCred
|
2016-07-13 14:21:18 +08:00
|
|
|
|
2022-09-29 12:28:45 +08:00
|
|
|
const mcQuickStartGuide = "https://min.io/docs/minio/linux/reference/minio-mc.html#quickstart"
|
2021-06-18 11:27:04 +08:00
|
|
|
|
2016-07-13 14:21:18 +08:00
|
|
|
// Configure 'mc', following block prints platform specific information for minio client.
|
2024-03-02 05:09:42 +08:00
|
|
|
if color.IsTerminal() && (!globalServerCtxt.Anonymous && globalAPIConfig.permitRootAccess()) {
|
2024-07-13 04:51:54 +08:00
|
|
|
logger.Startup(color.Blue("\nCLI: ") + mcQuickStartGuide)
|
2023-10-02 21:39:47 +08:00
|
|
|
mcMessage := fmt.Sprintf("$ mc alias set '%s' '%s' '%s' '%s'", alias,
|
|
|
|
endPoint, cred.AccessKey, cred.SecretKey)
|
2024-07-13 04:51:54 +08:00
|
|
|
logger.Startup(fmt.Sprintf(getFormatStr(len(mcMessage), 3), mcMessage))
|
2018-05-24 08:30:25 +08:00
|
|
|
}
|
2016-10-06 03:48:07 +08:00
|
|
|
}
|