mirror of
				https://github.com/caddyserver/caddy.git
				synced 2025-10-25 07:49:19 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			91 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			91 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package gzip
 | |
| 
 | |
| import (
 | |
| 	"net/http"
 | |
| 	"path"
 | |
| 
 | |
| 	"github.com/mholt/caddy/middleware"
 | |
| )
 | |
| 
 | |
| // Filter determines if a request should be gzipped.
 | |
| type Filter interface {
 | |
| 	// ShouldCompress tells if gzip compression
 | |
| 	// should be done on the request.
 | |
| 	ShouldCompress(*http.Request) bool
 | |
| }
 | |
| 
 | |
| // defaultExtensions is the list of default extensions for which to enable gzipping.
 | |
| var defaultExtensions = []string{"", ".txt", ".htm", ".html", ".css", ".php", ".js", ".json", ".md", ".xml"}
 | |
| 
 | |
| // DefaultExtFilter creates an ExtFilter with default extensions.
 | |
| func DefaultExtFilter() ExtFilter {
 | |
| 	m := ExtFilter{Exts: make(Set)}
 | |
| 	for _, extension := range defaultExtensions {
 | |
| 		m.Exts.Add(extension)
 | |
| 	}
 | |
| 	return m
 | |
| }
 | |
| 
 | |
| // ExtFilter is Filter for file name extensions.
 | |
| type ExtFilter struct {
 | |
| 	// Exts is the file name extensions to accept
 | |
| 	Exts Set
 | |
| }
 | |
| 
 | |
| // extWildCard is the wildcard for extensions.
 | |
| const ExtWildCard = "*"
 | |
| 
 | |
| // ShouldCompress checks if the request file extension matches any
 | |
| // of the registered extensions. It returns true if the extension is
 | |
| // found and false otherwise.
 | |
| func (e ExtFilter) ShouldCompress(r *http.Request) bool {
 | |
| 	ext := path.Ext(r.URL.Path)
 | |
| 	return e.Exts.Contains(ExtWildCard) || e.Exts.Contains(ext)
 | |
| }
 | |
| 
 | |
| // PathFilter is Filter for request path.
 | |
| type PathFilter struct {
 | |
| 	// IgnoredPaths is the paths to ignore
 | |
| 	IgnoredPaths Set
 | |
| }
 | |
| 
 | |
| // ShouldCompress checks if the request path matches any of the
 | |
| // registered paths to ignore. It returns false if an ignored path
 | |
| // is found and true otherwise.
 | |
| func (p PathFilter) ShouldCompress(r *http.Request) bool {
 | |
| 	return !p.IgnoredPaths.ContainsFunc(func(value string) bool {
 | |
| 		return middleware.Path(r.URL.Path).Matches(value)
 | |
| 	})
 | |
| }
 | |
| 
 | |
| // Set stores distinct strings.
 | |
| type Set map[string]struct{}
 | |
| 
 | |
| // Add adds an element to the set.
 | |
| func (s Set) Add(value string) {
 | |
| 	s[value] = struct{}{}
 | |
| }
 | |
| 
 | |
| // Remove removes an element from the set.
 | |
| func (s Set) Remove(value string) {
 | |
| 	delete(s, value)
 | |
| }
 | |
| 
 | |
| // Contains check if the set contains value.
 | |
| func (s Set) Contains(value string) bool {
 | |
| 	_, ok := s[value]
 | |
| 	return ok
 | |
| }
 | |
| 
 | |
| // ContainsFunc is similar to Contains. It iterates all the
 | |
| // elements in the set and passes each to f. It returns true
 | |
| // on the first call to f that returns true and false otherwise.
 | |
| func (s Set) ContainsFunc(f func(string) bool) bool {
 | |
| 	for k, _ := range s {
 | |
| 		if f(k) {
 | |
| 			return true
 | |
| 		}
 | |
| 	}
 | |
| 	return false
 | |
| }
 |