github.com/m3db/m3@v1.5.1-0.20231129193456-75a402aa583b/src/m3ninx/persist/types.go (about)

     1  // Copyright (c) 2018 Uber Technologies, Inc.
     2  //
     3  // Permission is hereby granted, free of charge, to any person obtaining a copy
     4  // of this software and associated documentation files (the "Software"), to deal
     5  // in the Software without restriction, including without limitation the rights
     6  // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
     7  // copies of the Software, and to permit persons to whom the Software is
     8  // furnished to do so, subject to the following conditions:
     9  //
    10  // The above copyright notice and this permission notice shall be included in
    11  // all copies or substantial portions of the Software.
    12  //
    13  // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
    14  // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
    15  // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
    16  // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
    17  // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
    18  // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
    19  // THE SOFTWARE.
    20  
    21  package persist
    22  
    23  import (
    24  	"fmt"
    25  	"io"
    26  	"regexp"
    27  
    28  	"github.com/m3db/m3/src/m3ninx/index/segment"
    29  	"github.com/m3db/m3/src/x/mmap"
    30  )
    31  
    32  var (
    33  	// TypeRegex allows what can be used for a IndexSegmentType or
    34  	// IndexSegmentFileType, explicitly cannot use "-" as that can be
    35  	// then used as a separator elsewhere, also it ensures callers must
    36  	// use lower cased strings.
    37  	TypeRegex = regexp.MustCompile("^[a-z_]+$")
    38  )
    39  
    40  // IndexFileSetWriter is an index file set writer, it can write out many
    41  // segments.
    42  type IndexFileSetWriter interface {
    43  	// WriteSegmentFileSet writes a index segment file set.
    44  	WriteSegmentFileSet(segmentFileSet IndexSegmentFileSetWriter) error
    45  }
    46  
    47  // IndexSegmentFileSetWriter is an index segment file set writer.
    48  type IndexSegmentFileSetWriter interface {
    49  	SegmentType() IndexSegmentType
    50  	MajorVersion() int
    51  	MinorVersion() int
    52  	SegmentMetadata() []byte
    53  	Files() []IndexSegmentFileType
    54  	WriteFile(fileType IndexSegmentFileType, writer io.Writer) error
    55  }
    56  
    57  // MutableSegmentFileSetWriter is a new IndexSegmentFileSetWriter for writing
    58  // out Mutable Segments.
    59  type MutableSegmentFileSetWriter interface {
    60  	IndexSegmentFileSetWriter
    61  
    62  	// Reset resets the writer to write the provided mutable segment.
    63  	Reset(segment.Builder) error
    64  }
    65  
    66  // IndexFileSetReader is an index file set reader, it can read many segments.
    67  type IndexFileSetReader interface {
    68  	// SegmentFileSets returns the number of segment file sets.
    69  	SegmentFileSets() int
    70  
    71  	// ReadSegmentFileSet returns the next segment file set or an error.
    72  	// It will return io.EOF error when no more file sets remain.
    73  	// The IndexSegmentFileSet will only be valid before it's closed,
    74  	// after that calls to Read or Bytes on it will have unexpected results.
    75  	ReadSegmentFileSet() (IndexSegmentFileSet, error)
    76  
    77  	IndexVolumeType() IndexVolumeType
    78  }
    79  
    80  // IndexSegmentFileSet is an index segment file set.
    81  type IndexSegmentFileSet interface {
    82  	SegmentType() IndexSegmentType
    83  	MajorVersion() int
    84  	MinorVersion() int
    85  	SegmentMetadata() []byte
    86  	Files() []IndexSegmentFile
    87  }
    88  
    89  // IndexSegmentFile is a file in an index segment file set.
    90  type IndexSegmentFile interface {
    91  	io.Reader
    92  	io.Closer
    93  
    94  	// SegmentFileType returns the segment file type.
    95  	SegmentFileType() IndexSegmentFileType
    96  
    97  	// Mmap will be valid until the segment file is closed.
    98  	Mmap() (mmap.Descriptor, error)
    99  }
   100  
   101  // IndexVolumeType is the type of an index volume.
   102  type IndexVolumeType string
   103  
   104  const (
   105  	// DefaultIndexVolumeType is a default IndexVolumeType.
   106  	// This is the type if not otherwise specified.
   107  	DefaultIndexVolumeType IndexVolumeType = "default"
   108  )
   109  
   110  // IndexSegmentType is the type of an index file set.
   111  type IndexSegmentType string
   112  
   113  const (
   114  	// FSTIndexSegmentType is a FST IndexSegmentType.
   115  	FSTIndexSegmentType IndexSegmentType = "fst"
   116  )
   117  
   118  // IndexSegmentFileType is the type of a file in an index file set.
   119  type IndexSegmentFileType string
   120  
   121  const (
   122  	// DocumentDataIndexSegmentFileType is a document data segment file.
   123  	DocumentDataIndexSegmentFileType IndexSegmentFileType = "docdata"
   124  
   125  	// DocumentIndexIndexSegmentFileType is a document index segment file.
   126  	DocumentIndexIndexSegmentFileType IndexSegmentFileType = "docidx"
   127  
   128  	// PostingsIndexSegmentFileType is a postings List data index segment file.
   129  	PostingsIndexSegmentFileType IndexSegmentFileType = "postingsdata"
   130  
   131  	// FSTFieldsIndexSegmentFileType is a FST Fields index segment file.
   132  	FSTFieldsIndexSegmentFileType IndexSegmentFileType = "fstfields"
   133  
   134  	// FSTTermsIndexSegmentFileType is a FST Terms index segment file.
   135  	FSTTermsIndexSegmentFileType IndexSegmentFileType = "fstterms"
   136  )
   137  
   138  var (
   139  	indexSegmentTypes = []IndexSegmentType{
   140  		FSTIndexSegmentType,
   141  	}
   142  
   143  	indexSegmentFileTypes = []IndexSegmentFileType{
   144  		DocumentDataIndexSegmentFileType,
   145  		DocumentIndexIndexSegmentFileType,
   146  		PostingsIndexSegmentFileType,
   147  		FSTFieldsIndexSegmentFileType,
   148  		FSTTermsIndexSegmentFileType,
   149  	}
   150  )
   151  
   152  func init() {
   153  	for _, f := range indexSegmentTypes {
   154  		if err := f.Validate(); err != nil {
   155  			panic(err)
   156  		}
   157  	}
   158  	for _, f := range indexSegmentFileTypes {
   159  		if err := f.Validate(); err != nil {
   160  			panic(err)
   161  		}
   162  	}
   163  }
   164  
   165  // Validate validates whether the string value is a valid segment type
   166  // and contains only lowercase a-z and underscore characters.
   167  func (t IndexSegmentType) Validate() error {
   168  	s := string(t)
   169  	if t == "" || !TypeRegex.MatchString(s) {
   170  		return fmt.Errorf("invalid segment type must match pattern=%s",
   171  			TypeRegex.String())
   172  	}
   173  	return nil
   174  }
   175  
   176  // Validate validates whether the string value is a valid segment file type
   177  // and contains only lowercase a-z and underscore characters.
   178  func (t IndexSegmentFileType) Validate() error {
   179  	s := string(t)
   180  	if t == "" || !TypeRegex.MatchString(s) {
   181  		return fmt.Errorf("invalid segment file type must match pattern=%s",
   182  			TypeRegex.String())
   183  	}
   184  	return nil
   185  }