mirror of
				https://github.com/caddyserver/caddy.git
				synced 2025-10-25 15:52:45 -04:00 
			
		
		
		
	We had to hack some special support into the server and caddy packages for this. There are some middlewares which should only execute commands when the original parent process first starts up. For example, someone using the startup directive to start a backend service would not expect the command to be executed every time the config was reloaded or changed - only once when they first started the original caddy process. This commit adds FirstStartup to the virtualhost config
		
			
				
	
	
		
			76 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package server
 | |
| 
 | |
| import (
 | |
| 	"net"
 | |
| 
 | |
| 	"github.com/mholt/caddy/middleware"
 | |
| )
 | |
| 
 | |
| // Config configuration for a single server.
 | |
| type Config struct {
 | |
| 	// The hostname or IP on which to serve
 | |
| 	Host string
 | |
| 
 | |
| 	// The host address to bind on - defaults to (virtual) Host if empty
 | |
| 	BindHost string
 | |
| 
 | |
| 	// The port to listen on
 | |
| 	Port string
 | |
| 
 | |
| 	// The directory from which to serve files
 | |
| 	Root string
 | |
| 
 | |
| 	// HTTPS configuration
 | |
| 	TLS TLSConfig
 | |
| 
 | |
| 	// Middleware stack; map of path scope to middleware -- TODO: Support path scope?
 | |
| 	Middleware map[string][]middleware.Middleware
 | |
| 
 | |
| 	// Startup is a list of functions (or methods) to execute at
 | |
| 	// server startup and restart; these are executed before any
 | |
| 	// parts of the server are configured, and the functions are
 | |
| 	// blocking. These are good for setting up middlewares and
 | |
| 	// starting goroutines.
 | |
| 	Startup []func() error
 | |
| 
 | |
| 	// FirstStartup is like Startup but these functions only execute
 | |
| 	// during the initial startup, not on subsequent restarts.
 | |
| 	//
 | |
| 	// (Note: The server does not ever run these on its own; it is up
 | |
| 	// to the calling application to do so, and do so only once, as the
 | |
| 	// server itself has no notion whether it's a restart or not.)
 | |
| 	FirstStartup []func() error
 | |
| 
 | |
| 	// Functions (or methods) to execute when the server quits;
 | |
| 	// these are executed in response to SIGINT and are blocking
 | |
| 	Shutdown []func() error
 | |
| 
 | |
| 	// The path to the configuration file from which this was loaded
 | |
| 	ConfigFile string
 | |
| 
 | |
| 	// The name of the application
 | |
| 	AppName string
 | |
| 
 | |
| 	// The application's version
 | |
| 	AppVersion string
 | |
| }
 | |
| 
 | |
| // Address returns the host:port of c as a string.
 | |
| func (c Config) Address() string {
 | |
| 	return net.JoinHostPort(c.Host, c.Port)
 | |
| }
 | |
| 
 | |
| // TLSConfig describes how TLS should be configured and used.
 | |
| type TLSConfig struct {
 | |
| 	Enabled                  bool
 | |
| 	Certificate              string
 | |
| 	Key                      string
 | |
| 	LetsEncryptEmail         string
 | |
| 	OCSPStaple               []byte
 | |
| 	Ciphers                  []uint16
 | |
| 	ProtocolMinVersion       uint16
 | |
| 	ProtocolMaxVersion       uint16
 | |
| 	PreferServerCipherSuites bool
 | |
| 	ClientCerts              []string
 | |
| }
 |