| 
									
										
										
										
											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
										 |  |  | } |