52 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Go
		
	
	
	
package rules
 | 
						|
 | 
						|
import (
 | 
						|
	"path/filepath"
 | 
						|
	"regexp"
 | 
						|
	"strings"
 | 
						|
)
 | 
						|
 | 
						|
// Checker is a Rules checker.
 | 
						|
type Checker interface {
 | 
						|
	Check(path string) bool
 | 
						|
}
 | 
						|
 | 
						|
// Rule is a allow/disallow rule.
 | 
						|
type Rule struct {
 | 
						|
	Regex  bool    `json:"regex"`
 | 
						|
	Allow  bool    `json:"allow"`
 | 
						|
	Path   string  `json:"path"`
 | 
						|
	Regexp *Regexp `json:"regexp"`
 | 
						|
}
 | 
						|
 | 
						|
// MatchHidden matches paths with a basename
 | 
						|
// that begins with a dot.
 | 
						|
func MatchHidden(path string) bool {
 | 
						|
	return path != "" && strings.HasPrefix(filepath.Base(path), ".")
 | 
						|
}
 | 
						|
 | 
						|
// Matches matches a path against a rule.
 | 
						|
func (r *Rule) Matches(path string) bool {
 | 
						|
	if r.Regex {
 | 
						|
		return r.Regexp.MatchString(path)
 | 
						|
	}
 | 
						|
 | 
						|
	return strings.HasPrefix(path, r.Path)
 | 
						|
}
 | 
						|
 | 
						|
// Regexp is a wrapper to the native regexp type where we
 | 
						|
// save the raw expression.
 | 
						|
type Regexp struct {
 | 
						|
	Raw    string `json:"raw"`
 | 
						|
	regexp *regexp.Regexp
 | 
						|
}
 | 
						|
 | 
						|
// MatchString checks if a string matches the regexp.
 | 
						|
func (r *Regexp) MatchString(s string) bool {
 | 
						|
	if r.regexp == nil {
 | 
						|
		r.regexp = regexp.MustCompile(r.Raw)
 | 
						|
	}
 | 
						|
 | 
						|
	return r.regexp.MatchString(s)
 | 
						|
}
 |