mirror of
				https://github.com/StackExchange/dnscontrol.git
				synced 2024-05-11 05:55:12 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			105 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			105 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package rejectif
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"strings"
 | |
| 
 | |
| 	"github.com/StackExchange/dnscontrol/v4/models"
 | |
| )
 | |
| 
 | |
| // Keep these in alphabetical order.
 | |
| 
 | |
| // TxtHasBackticks audits TXT records for strings that contain backticks.
 | |
| func TxtHasBackticks(rc *models.RecordConfig) error {
 | |
| 	for _, txt := range rc.TxtStrings {
 | |
| 		if strings.Contains(txt, "`") {
 | |
| 			return fmt.Errorf("txtstring contains backtick")
 | |
| 		}
 | |
| 	}
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // TxtHasSingleQuotes audits TXT records for strings that contain single-quotes.
 | |
| func TxtHasSingleQuotes(rc *models.RecordConfig) error {
 | |
| 	for _, txt := range rc.TxtStrings {
 | |
| 		if strings.Contains(txt, "'") {
 | |
| 			return fmt.Errorf("txtstring contains single-quotes")
 | |
| 		}
 | |
| 	}
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // TxtHasDoubleQuotes audits TXT records for strings that contain doublequotes.
 | |
| func TxtHasDoubleQuotes(rc *models.RecordConfig) error {
 | |
| 	for _, txt := range rc.TxtStrings {
 | |
| 		if strings.Contains(txt, `"`) {
 | |
| 			return fmt.Errorf("txtstring contains doublequotes")
 | |
| 		}
 | |
| 	}
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // TxtIsExactlyLen255 audits TXT records for strings exactly 255 octets long.
 | |
| // This is rare; you probably want to use TxtNoStringsLen256orLonger() instead.
 | |
| func TxtIsExactlyLen255(rc *models.RecordConfig) error {
 | |
| 	for _, txt := range rc.TxtStrings {
 | |
| 		if len(txt) == 255 {
 | |
| 			return fmt.Errorf("txtstring length is 255")
 | |
| 		}
 | |
| 	}
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // TxtHasSegmentLen256orLonger audits TXT records for strings that are >255 octets.
 | |
| func TxtHasSegmentLen256orLonger(rc *models.RecordConfig) error {
 | |
| 	for _, txt := range rc.TxtStrings {
 | |
| 		if len(txt) > 255 {
 | |
| 			return fmt.Errorf("%q txtstring length > 255", rc.GetLabel())
 | |
| 		}
 | |
| 	}
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // TxtHasMultipleSegments audits TXT records for multiple strings
 | |
| func TxtHasMultipleSegments(rc *models.RecordConfig) error {
 | |
| 	if len(rc.TxtStrings) > 1 {
 | |
| 		return fmt.Errorf("multiple strings in one txt")
 | |
| 	}
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // TxtHasTrailingSpace audits TXT records for strings that end with space.
 | |
| func TxtHasTrailingSpace(rc *models.RecordConfig) error {
 | |
| 	for _, txt := range rc.TxtStrings {
 | |
| 		if txt != "" && txt[ultimate(txt)] == ' ' {
 | |
| 			return fmt.Errorf("txtstring ends with space")
 | |
| 		}
 | |
| 	}
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // TxtIsEmpty audits TXT records for empty strings.
 | |
| func TxtIsEmpty(rc *models.RecordConfig) error {
 | |
| 	// There must be strings.
 | |
| 	if len(rc.TxtStrings) == 0 {
 | |
| 		return fmt.Errorf("txt with no strings")
 | |
| 	}
 | |
| 	// Each string must be non-empty.
 | |
| 	for _, txt := range rc.TxtStrings {
 | |
| 		if len(txt) == 0 {
 | |
| 			return fmt.Errorf("txtstring is empty")
 | |
| 		}
 | |
| 	}
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // TxtHasUnpairedDoubleQuotes audits TXT records for strings that contain unpaired doublequotes.
 | |
| func TxtHasUnpairedDoubleQuotes(rc *models.RecordConfig) error {
 | |
| 	for _, txt := range rc.TxtStrings {
 | |
| 		if strings.Count(txt, `"`)%2 == 1 {
 | |
| 			return fmt.Errorf("txtstring contains unpaired doublequotes")
 | |
| 		}
 | |
| 	}
 | |
| 	return nil
 | |
| }
 |