mirror of
				https://github.com/caddyserver/caddy.git
				synced 2025-10-26 08:12:43 -04:00 
			
		
		
		
	* caddytls: Prefer managed wildcard certs over individual subdomain certs * Repurpose force_automate as no_wildcard * Fix a couple bugs * Restore force_automate and use automate loader as wildcard override
		
			
				
	
	
		
			23 lines
		
	
	
		
			917 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			23 lines
		
	
	
		
			917 B
		
	
	
	
		
			Go
		
	
	
	
	
	
| package internal
 | |
| 
 | |
| import "fmt"
 | |
| 
 | |
| // MaxSizeSubjectsListForLog returns the keys in the map as a slice of maximum length
 | |
| // maxToDisplay. It is useful for logging domains being managed, for example, since a
 | |
| // map is typically needed for quick lookup, but a slice is needed for logging, and this
 | |
| // can be quite a doozy since there may be a huge amount (hundreds of thousands).
 | |
| func MaxSizeSubjectsListForLog(subjects map[string]struct{}, maxToDisplay int) []string {
 | |
| 	numberOfNamesToDisplay := min(len(subjects), maxToDisplay)
 | |
| 	domainsToDisplay := make([]string, 0, numberOfNamesToDisplay)
 | |
| 	for domain := range subjects {
 | |
| 		domainsToDisplay = append(domainsToDisplay, domain)
 | |
| 		if len(domainsToDisplay) >= numberOfNamesToDisplay {
 | |
| 			break
 | |
| 		}
 | |
| 	}
 | |
| 	if len(subjects) > maxToDisplay {
 | |
| 		domainsToDisplay = append(domainsToDisplay, fmt.Sprintf("(and %d more...)", len(subjects)-maxToDisplay))
 | |
| 	}
 | |
| 	return domainsToDisplay
 | |
| }
 |